slice-machine-ui 2.18.1-alpha.jp-unauthorized-error-improvement.8 → 2.18.1-alpha.jp-remove-shared-onboarding-experiment.1

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 (83) hide show
  1. package/out/404.html +1 -1
  2. package/out/_next/static/3vhVTMa6keo8tGH6Ngo6o/_buildManifest.js +1 -0
  3. package/out/_next/static/chunks/157-fa8b348c960c8283.js +3 -0
  4. package/out/_next/static/chunks/{248-a9c33f7fbe2da2f1.js → 248-43faecb386a16518.js} +1 -1
  5. package/out/_next/static/chunks/256-07f768a2b19b0a0e.js +4 -0
  6. package/out/_next/static/chunks/34-8d9d9b2944824750.js +1 -0
  7. package/out/_next/static/chunks/344-fdb3008f4bb3b0c1.js +1 -0
  8. package/out/_next/static/chunks/484-3e011e79c41f0342.js +1 -0
  9. package/out/_next/static/chunks/{489-a046ae0fa4f74435.js → 489-234ed5471aa694b3.js} +1 -1
  10. package/out/_next/static/chunks/500-d3989390f5e8da53.js +1 -0
  11. package/out/_next/static/chunks/52d4c156-89c6ec6efca0a0bb.js +1 -0
  12. package/out/_next/static/chunks/630-c134ff151304ad46.js +1 -0
  13. package/out/_next/static/chunks/pages/{_app-6ee99840ce68524b.js → _app-9eab6434508c5ef3.js} +105 -105
  14. package/out/_next/static/chunks/pages/{changelog-3901f2fc937d9648.js → changelog-ba55ed247c20dc21.js} +1 -1
  15. package/out/_next/static/chunks/pages/changes-e04a225a3be52470.js +1 -0
  16. package/out/_next/static/chunks/pages/custom-types/{[customTypeId]-816acb31b652239b.js → [customTypeId]-af9376721beb489e.js} +1 -1
  17. package/out/_next/static/chunks/pages/{labs-dd04033db23a58f3.js → labs-78ac01d97ab02cd7.js} +1 -1
  18. package/out/_next/static/chunks/pages/page-types/{[pageTypeId]-669d5479e81b638b.js → [pageTypeId]-a24665e91b882169.js} +1 -1
  19. package/out/_next/static/chunks/pages/slices/[lib]/[sliceName]/[variation]/{simulator-f237aaa755dc9a99.js → simulator-b127d948a17968d3.js} +1 -1
  20. package/out/_next/static/chunks/pages/slices/[lib]/[sliceName]/[variation]-da423aa0da7bc11e.js +1 -0
  21. package/out/_next/static/chunks/pages/slices-59b857edc9f72d5f.js +1 -0
  22. package/out/_next/static/css/{303dad78be1eb854.css → bc89f2cd4e4781f5.css} +1 -1
  23. package/out/_next/static/css/e8e03c0d4003d1eb.css +1 -0
  24. package/out/changelog.html +1 -1
  25. package/out/changes.html +1 -1
  26. package/out/custom-types/[customTypeId].html +1 -1
  27. package/out/custom-types.html +1 -1
  28. package/out/index.html +1 -1
  29. package/out/labs.html +1 -1
  30. package/out/page-types/[pageTypeId].html +1 -1
  31. package/out/slices/[lib]/[sliceName]/[variation]/simulator.html +1 -1
  32. package/out/slices/[lib]/[sliceName]/[variation].html +1 -1
  33. package/out/slices.html +1 -1
  34. package/package.json +3 -3
  35. package/src/{features/errorBoundaries/DefaultErrorBoundary.tsx → ErrorBoundary.tsx} +2 -2
  36. package/src/features/auth/LogoutButton.tsx +36 -42
  37. package/src/features/builder/fields/contentRelationship/ContentRelationshipFieldPicker.tsx +3 -3
  38. package/src/features/changes/StatusBadge.tsx +9 -1
  39. package/src/features/customTypes/customTypesBuilder/PageSnippetDialog/PageSnippetDialog.tsx +3 -3
  40. package/src/features/customTypes/customTypesTable/CustomTypesTablePage.tsx +3 -3
  41. package/src/features/environments/actions/setEnvironment.ts +18 -0
  42. package/src/features/environments/useActiveEnvironment.ts +9 -17
  43. package/src/features/environments/useEnvironments.ts +8 -11
  44. package/src/features/labs/labsList/LabsPage.tsx +3 -3
  45. package/src/features/navigation/Navigation.tsx +8 -7
  46. package/src/features/navigation/RepositoryInfo.tsx +24 -18
  47. package/src/features/onboarding/OnboardingGuide.tsx +2 -5
  48. package/src/features/onboarding/useOnboarding.ts +1 -14
  49. package/src/features/slices/sliceBuilder/FloatingBackButton.tsx +3 -3
  50. package/src/features/sync/AutoSyncProvider.tsx +2 -2
  51. package/src/features/sync/getUnSyncChanges.ts +3 -1
  52. package/src/legacy/components/AppLayout/index.tsx +85 -10
  53. package/src/legacy/components/ChangesEmptyState/AuthErrorPage.tsx +44 -0
  54. package/src/legacy/components/ChangesEmptyState/index.ts +1 -1
  55. package/src/legacy/components/ChangesItems/ChangesItems.tsx +3 -3
  56. package/src/legacy/components/LoginModal/index.tsx +6 -14
  57. package/src/legacy/components/Navigation/ChangesItem.tsx +48 -96
  58. package/src/legacy/components/Navigation/Environment.tsx +7 -2
  59. package/src/legacy/components/Navigation/SideNavEnvironmentSelector/SideNavEnvironmentSelector.tsx +8 -3
  60. package/src/legacy/components/Simulator/index.tsx +3 -3
  61. package/src/legacy/lib/builders/CustomTypeBuilder/TabZone/index.tsx +3 -3
  62. package/src/modules/userContext/index.ts +5 -5
  63. package/src/modules/userContext/types.ts +3 -2
  64. package/src/pages/_app.tsx +95 -93
  65. package/src/pages/changes.tsx +5 -4
  66. package/test/__testutils__/index.tsx +10 -13
  67. package/out/_next/static/0C8VxwongjXZwHPchBnOi/_buildManifest.js +0 -1
  68. package/out/_next/static/chunks/34-50c64778da33cff6.js +0 -1
  69. package/out/_next/static/chunks/349-7118116b93278f73.js +0 -4
  70. package/out/_next/static/chunks/429-1137c819c2bf6b66.js +0 -3
  71. package/out/_next/static/chunks/50-586dc7ab5e584e76.js +0 -1
  72. package/out/_next/static/chunks/630-eae75e90b30f201a.js +0 -1
  73. package/out/_next/static/chunks/pages/changes-c58a60af39167147.js +0 -1
  74. package/out/_next/static/chunks/pages/slices/[lib]/[sliceName]/[variation]-e6bc7cc6186d6a0f.js +0 -1
  75. package/out/_next/static/chunks/pages/slices-bf63f937b184b470.js +0 -1
  76. package/out/_next/static/css/cdee5b195444f185.css +0 -1
  77. package/src/features/environments/actions/useSetEnvironment.ts +0 -22
  78. package/src/features/errorBoundaries/AppStateErrorBoundary.tsx +0 -108
  79. package/src/features/errorBoundaries/index.ts +0 -2
  80. package/src/features/onboarding/useSharedOnboardingExperiment.ts +0 -6
  81. package/src/legacy/components/ChangesEmptyState/UnauthenticatedView.tsx +0 -31
  82. package/src/queryClient.tsx +0 -24
  83. /package/out/_next/static/{0C8VxwongjXZwHPchBnOi → 3vhVTMa6keo8tGH6Ngo6o}/_ssgManifest.js +0 -0
@@ -17,8 +17,9 @@ import * as VisuallyHidden from "@radix-ui/react-visually-hidden";
17
17
  import type { Environment } from "@slicemachine/manager/client";
18
18
  import { clsx } from "clsx";
19
19
  import type { FC, ReactNode } from "react";
20
+ import { toast } from "react-toastify";
20
21
 
21
- import { EnvironmentLogoutButton } from "@/features/auth/LogoutButton";
22
+ import { LogoutButton } from "@/features/auth/LogoutButton";
22
23
  import { LoginIcon } from "@/icons/LoginIcon";
23
24
  import { LogoIcon } from "@/icons/LogoIcon";
24
25
 
@@ -29,7 +30,7 @@ type SideNavEnvironmentSelectorProps = {
29
30
  disabled?: boolean;
30
31
  environments?: Environment[];
31
32
  loading?: boolean;
32
- variant?: "default" | "offline" | "unauthenticated";
33
+ variant?: "default" | "offline" | "unauthorized" | "unauthenticated";
33
34
  onLogInClick?: () => void;
34
35
  onSelect?: (environment: Environment) => void | Promise<void>;
35
36
  };
@@ -140,7 +141,11 @@ export const SideNavEnvironmentSelector: FC<SideNavEnvironmentSelectorProps> = (
140
141
  />
141
142
  ) : undefined}
142
143
 
143
- {variant === "default" && <EnvironmentLogoutButton />}
144
+ {variant === "default" && (
145
+ <LogoutButton
146
+ onLogoutSuccess={() => toast.success("Logged out")}
147
+ />
148
+ )}
144
149
  </Box>
145
150
  </>
146
151
  )}
@@ -17,7 +17,7 @@ import { toast } from "react-toastify";
17
17
  import { BaseStyles, Box, Flex, Spinner } from "theme-ui";
18
18
 
19
19
  import { saveSliceMock, telemetry } from "@/apiClient";
20
- import { DefaultErrorBoundary } from "@/features/errorBoundaries";
20
+ import { ErrorBoundary } from "@/ErrorBoundary";
21
21
  import useThrottle from "@/hooks/useThrottle";
22
22
  import ScreenshotPreviewModal from "@/legacy/components/ScreenshotPreviewModal";
23
23
  import { ComponentUI } from "@/legacy/lib/models/common/ComponentUI";
@@ -287,7 +287,7 @@ const Simulator: FC<SimulatorProps> = ({ slice, variation }) => {
287
287
  overflowY: "auto",
288
288
  }}
289
289
  >
290
- <DefaultErrorBoundary
290
+ <ErrorBoundary
291
291
  renderError={() => (
292
292
  <DefaultErrorMessage
293
293
  title="Editor error"
@@ -315,7 +315,7 @@ const Simulator: FC<SimulatorProps> = ({ slice, variation }) => {
315
315
  />
316
316
  </QueryClientProvider>
317
317
  </Suspense>
318
- </DefaultErrorBoundary>
318
+ </ErrorBoundary>
319
319
  </Flex>
320
320
  ) : null}
321
321
  </Flex>
@@ -20,8 +20,8 @@ import {
20
20
  reorderField,
21
21
  updateField,
22
22
  } from "@/domain/customType";
23
+ import { ErrorBoundary } from "@/ErrorBoundary";
23
24
  import { useCustomTypeState } from "@/features/customTypes/customTypesBuilder/CustomTypeProvider";
24
- import { DefaultErrorBoundary } from "@/features/errorBoundaries";
25
25
  import {
26
26
  CustomTypes,
27
27
  type TabField,
@@ -246,7 +246,7 @@ const TabZone: FC<TabZoneProps> = ({ tabId }) => {
246
246
  };
247
247
 
248
248
  return (
249
- <DefaultErrorBoundary>
249
+ <ErrorBoundary>
250
250
  <Suspense
251
251
  fallback={
252
252
  <Box padding={32}>
@@ -297,7 +297,7 @@ const TabZone: FC<TabZoneProps> = ({ tabId }) => {
297
297
  />
298
298
  </List>
299
299
  </Suspense>
300
- </DefaultErrorBoundary>
300
+ </ErrorBoundary>
301
301
  );
302
302
  };
303
303
 
@@ -1,4 +1,3 @@
1
- import { UnauthenticatedError } from "@slicemachine/manager/client";
2
1
  import { Reducer } from "redux";
3
2
  import { ActionType, createAction, getType } from "typesafe-actions";
4
3
 
@@ -91,12 +90,13 @@ const getAuthStatus = (
91
90
  ): AuthStatus => {
92
91
  switch (clientError?.status) {
93
92
  case undefined: {
94
- return AuthStatus.AUTHENTICATED;
93
+ return AuthStatus.AUTHORIZED;
94
+ }
95
+ case 403: {
96
+ return AuthStatus.UNAUTHORIZED;
95
97
  }
96
98
  case 401: {
97
- if (clientError.name === new UnauthenticatedError().name) {
98
- return AuthStatus.UNAUTHENTICATED;
99
- }
99
+ return AuthStatus.FORBIDDEN;
100
100
  }
101
101
  default: {
102
102
  return AuthStatus.UNKNOWN;
@@ -1,6 +1,7 @@
1
1
  export enum AuthStatus {
2
- AUTHENTICATED = "authenticated",
3
- UNAUTHENTICATED = "unauthenticated",
2
+ AUTHORIZED = "authorized",
3
+ UNAUTHORIZED = "unauthorized",
4
+ FORBIDDEN = "forbidden",
4
5
  UNKNOWN = "unknown",
5
6
  }
6
7
 
@@ -13,33 +13,34 @@ import "@/styles/starry-night.css";
13
13
  import "@/styles/tabs.css";
14
14
  import "@/styles/toaster.css";
15
15
 
16
- import { ThemeProvider, TooltipProvider } from "@prismicio/editor-ui";
17
16
  import {
18
- isInvalidActiveEnvironmentError,
19
- isUnauthorizedError,
20
- } from "@slicemachine/manager/client";
21
- import { useSuspenseQuery } from "@tanstack/react-query";
22
- import { ConnectedRouter as StoreConnectedRouter } from "connected-next-router";
17
+ Box,
18
+ DefaultErrorMessage,
19
+ ThemeProvider,
20
+ TooltipProvider,
21
+ } from "@prismicio/editor-ui";
22
+ import { ConnectedRouter } from "connected-next-router";
23
23
  import type { NextPage } from "next";
24
24
  import type { AppContext, AppInitialProps } from "next/app";
25
25
  import dynamic from "next/dynamic";
26
26
  import Head from "next/head";
27
27
  import Router from "next/router";
28
- import { type FC, type ReactNode, Suspense, useEffect } from "react";
28
+ import { type FC, type ReactNode, Suspense, useEffect, useState } from "react";
29
29
  import { Provider } from "react-redux";
30
+ import type { Store } from "redux";
31
+ import type { Persistor } from "redux-persist/es/types";
30
32
  import { PersistGate } from "redux-persist/integration/react";
31
33
  import { ThemeProvider as ThemeUIThemeProvider, useThemeUI } from "theme-ui";
32
34
 
33
35
  import { getState } from "@/apiClient";
34
- import { useActiveEnvironment } from "@/features/environments/useActiveEnvironment";
35
- import { AppStateErrorBoundary } from "@/features/errorBoundaries";
36
+ import { ErrorBoundary } from "@/ErrorBoundary";
36
37
  import { AutoSyncProvider } from "@/features/sync/AutoSyncProvider";
37
38
  import { RouteChangeProvider } from "@/hooks/useRouteChange";
38
39
  import SliceMachineApp from "@/legacy/components/App";
39
40
  import LoadingPage from "@/legacy/components/LoadingPage";
40
41
  import ToastContainer from "@/legacy/components/ToasterContainer";
41
42
  import { normalizeFrontendCustomTypes } from "@/legacy/lib/models/common/normalizers/customType";
42
- import { QueryClientProvider } from "@/queryClient";
43
+ import type ServerState from "@/legacy/lib/models/server/ServerState";
43
44
  import configureStore from "@/redux/store";
44
45
  import theme from "@/theme";
45
46
 
@@ -67,10 +68,50 @@ const RemoveDarkMode: FC<RemoveDarkModeProps> = ({ children }) => {
67
68
  return <>{children}</>;
68
69
  };
69
70
 
70
- function App(props: AppContextWithComponentLayout & AppInitialProps) {
71
- const { Component } = props;
71
+ function App({
72
+ Component,
73
+ pageProps,
74
+ }: AppContextWithComponentLayout & AppInitialProps) {
75
+ const [serverState, setServerState] = useState<ServerState | null>(null);
76
+ const [smStore, setSMStore] = useState<{
77
+ store: Store;
78
+ persistor: Persistor;
79
+ } | null>(null);
72
80
 
73
- const ComponentLayout = Component.CustomLayout ?? SliceMachineApp;
81
+ useEffect(() => {
82
+ async function getInitialState() {
83
+ const serverState = await getState();
84
+ setServerState(serverState);
85
+ }
86
+ void getInitialState();
87
+ }, []);
88
+
89
+ useEffect(() => {
90
+ if (!serverState || smStore) {
91
+ return;
92
+ }
93
+
94
+ const normalizedCustomTypes = normalizeFrontendCustomTypes(
95
+ serverState.customTypes,
96
+ serverState.remoteCustomTypes,
97
+ );
98
+
99
+ const { store, persistor } = configureStore({
100
+ environment: serverState.env,
101
+ availableCustomTypes: {
102
+ ...normalizedCustomTypes,
103
+ },
104
+ slices: {
105
+ libraries: serverState.libraries,
106
+ remoteSlices: serverState.remoteSlices,
107
+ },
108
+ });
109
+
110
+ setSMStore({ store, persistor });
111
+ }, [serverState, smStore]);
112
+
113
+ // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
114
+ const ComponentLayout = Component.CustomLayout || SliceMachineApp;
74
115
 
75
116
  return (
76
117
  <>
@@ -78,89 +119,50 @@ function App(props: AppContextWithComponentLayout & AppInitialProps) {
78
119
  <title>Slice Machine</title>
79
120
  </Head>
80
121
  <ThemeUIThemeProvider theme={theme}>
81
- <QueryClientProvider>
82
- <RemoveDarkMode>
83
- <ThemeProvider mode="light">
84
- <TooltipProvider>
85
- <AppStateErrorBoundary>
86
- <Suspense fallback={<LoadingPage />}>
87
- <AppStateValidator>
88
- <AppStateWrapper>
89
- <AutoSyncProvider>
90
- <ComponentLayout>
91
- <Component {...props.pageProps} />
92
- </ComponentLayout>
93
- </AutoSyncProvider>
94
- </AppStateWrapper>
95
- </AppStateValidator>
96
- </Suspense>
97
- </AppStateErrorBoundary>
98
- <ToastContainer />
99
- </TooltipProvider>
100
- </ThemeProvider>
101
- </RemoveDarkMode>
102
- </QueryClientProvider>
122
+ <RemoveDarkMode>
123
+ <ThemeProvider mode="light">
124
+ <TooltipProvider>
125
+ {!smStore || !serverState ? (
126
+ <LoadingPage />
127
+ ) : (
128
+ <Provider store={smStore.store}>
129
+ <ConnectedRouter Router={Router}>
130
+ <PersistGate loading={null} persistor={smStore.persistor}>
131
+ <ErrorBoundary
132
+ renderError={() => (
133
+ <Box
134
+ justifyContent="center"
135
+ width="100%"
136
+ padding={80}
137
+ >
138
+ <DefaultErrorMessage
139
+ title="Error"
140
+ description="An error occurred while rendering the app."
141
+ />
142
+ </Box>
143
+ )}
144
+ >
145
+ <Suspense fallback={<LoadingPage />}>
146
+ <AutoSyncProvider>
147
+ <RouteChangeProvider>
148
+ <ComponentLayout>
149
+ <Component {...pageProps} />
150
+ </ComponentLayout>
151
+ </RouteChangeProvider>
152
+ </AutoSyncProvider>
153
+ </Suspense>
154
+ </ErrorBoundary>
155
+ </PersistGate>
156
+ </ConnectedRouter>
157
+ <ToastContainer />
158
+ </Provider>
159
+ )}
160
+ </TooltipProvider>
161
+ </ThemeProvider>
162
+ </RemoveDarkMode>
103
163
  </ThemeUIThemeProvider>
104
164
  </>
105
165
  );
106
166
  }
107
167
 
108
- /** This is where we should check for unwanted states that should prevent the
109
- * user from using the app, and trigger the {@link AppStateErrorBoundary} to
110
- * display something explaining why. */
111
- function AppStateValidator(props: { children: ReactNode }) {
112
- const activeEnvironment = useActiveEnvironment({ suspense: true });
113
-
114
- if (
115
- // We're using the fetchEnvironments request to check this because it can
116
- // return an SMUnauthorizedError or SMInvalidActiveEnvironmentError
117
- // according to the API response, so we handle both cases with just one
118
- // request. We also perform the request in other parts of the app, so it can
119
- // reuse its cache.
120
- isUnauthorizedError(activeEnvironment.error) ||
121
- isInvalidActiveEnvironmentError(activeEnvironment.error)
122
- ) {
123
- throw activeEnvironment.error;
124
- }
125
-
126
- return <>{props.children}</>;
127
- }
128
-
129
- function AppStateWrapper({ children }: { children: ReactNode }) {
130
- const { data: state } = useSuspenseQuery({
131
- queryKey: ["getInitialState"],
132
- queryFn: async () => {
133
- const serverState = await getState();
134
- const { store, persistor } = configureStore({
135
- environment: serverState.env,
136
- availableCustomTypes: {
137
- ...normalizeFrontendCustomTypes(
138
- serverState.customTypes,
139
- serverState.remoteCustomTypes,
140
- ),
141
- },
142
- slices: {
143
- libraries: serverState.libraries,
144
- remoteSlices: serverState.remoteSlices,
145
- },
146
- });
147
-
148
- return { serverState, store, persistor };
149
- },
150
- // avoid refetching
151
- staleTime: Infinity,
152
- gcTime: Infinity,
153
- });
154
-
155
- return (
156
- <Provider store={state.store}>
157
- <StoreConnectedRouter Router={Router}>
158
- <PersistGate loading={null} persistor={state.persistor}>
159
- <RouteChangeProvider>{children}</RouteChangeProvider>
160
- </PersistGate>
161
- </StoreConnectedRouter>
162
- </Provider>
163
- );
164
- }
165
-
166
168
  export default dynamic(() => Promise.resolve(App), { ssr: false });
@@ -25,8 +25,8 @@ import {
25
25
  AppLayoutHeader,
26
26
  } from "@/legacy/components/AppLayout";
27
27
  import {
28
+ AuthErrorPage,
28
29
  OfflinePage,
29
- UnauthenticatedView,
30
30
  } from "@/legacy/components/ChangesEmptyState";
31
31
  import { ChangesItems } from "@/legacy/components/ChangesItems";
32
32
  import {
@@ -114,8 +114,8 @@ const Changes: React.FunctionComponent = () => {
114
114
  if (!isOnline) {
115
115
  return <OfflinePage />;
116
116
  }
117
- if (authStatus === AuthStatus.UNAUTHENTICATED) {
118
- return <UnauthenticatedView />;
117
+ if (authStatus === AuthStatus.FORBIDDEN) {
118
+ return <AuthErrorPage authStatus={authStatus} />;
119
119
  }
120
120
  if (numberOfChanges === 0) {
121
121
  return (
@@ -160,7 +160,8 @@ const Changes: React.FunctionComponent = () => {
160
160
  disabled={
161
161
  numberOfChanges === 0 ||
162
162
  !isOnline ||
163
- authStatus !== AuthStatus.AUTHENTICATED ||
163
+ authStatus === AuthStatus.UNAUTHORIZED ||
164
+ authStatus === AuthStatus.FORBIDDEN ||
164
165
  isSyncing
165
166
  }
166
167
  loading={isSyncing}
@@ -5,8 +5,7 @@ import { Provider } from "react-redux";
5
5
  import { AnyAction, Store } from "redux";
6
6
  import { BaseStyles, ThemeProvider as ThemeUIThemeProvider } from "theme-ui";
7
7
 
8
- import { DefaultErrorBoundary } from "@/features/errorBoundaries";
9
- import { QueryClientProvider } from "@/queryClient";
8
+ import { ErrorBoundary } from "@/ErrorBoundary";
10
9
 
11
10
  import configureStore from "../../src/redux/store";
12
11
  import type { SliceMachineStoreType } from "../../src/redux/type";
@@ -45,17 +44,15 @@ function render(
45
44
  children: any;
46
45
  }) {
47
46
  return (
48
- <QueryClientProvider>
49
- <ThemeUIThemeProvider theme={theme}>
50
- <TooltipProvider>
51
- <BaseStyles>
52
- <Provider store={store}>
53
- <DefaultErrorBoundary>{children}</DefaultErrorBoundary>
54
- </Provider>
55
- </BaseStyles>
56
- </TooltipProvider>
57
- </ThemeUIThemeProvider>
58
- </QueryClientProvider>
47
+ <ThemeUIThemeProvider theme={theme}>
48
+ <TooltipProvider>
49
+ <BaseStyles>
50
+ <Provider store={store}>
51
+ <ErrorBoundary>{children}</ErrorBoundary>
52
+ </Provider>
53
+ </BaseStyles>
54
+ </TooltipProvider>
55
+ </ThemeUIThemeProvider>
59
56
  );
60
57
  }
61
58
  return {
@@ -1 +0,0 @@
1
- self.__BUILD_MANIFEST=function(s,c,a,e,t,i,b,d,n,u,h,l,f,k,j,p,g,o,r,m){return{__rewrites:{afterFiles:[],beforeFiles:[],fallback:[]},"/":[s,e,p,g,"static/chunks/pages/index-0d8cb369de720a35.js"],"/_error":["static/chunks/pages/_error-fedd2c6ebd3d27b9.js"],"/changelog":[c,t,"static/chunks/870-a72b74312773efea.js","static/chunks/pages/changelog-3901f2fc937d9648.js"],"/changes":[c,i,"static/chunks/8eec4907-b712959d9f984b68.js","static/chunks/918-fa4f2563cb5fd014.js",a,d,"static/css/d98ebc475f8423a3.css","static/chunks/pages/changes-c58a60af39167147.js"],"/custom-types":[s,e,p,g,"static/chunks/pages/custom-types-5acd56959b60346f.js"],"/custom-types/[customTypeId]":[c,n,u,h,l,s,t,b,f,o,a,e,k,j,r,m,"static/chunks/pages/custom-types/[customTypeId]-816acb31b652239b.js"],"/labs":["static/chunks/pages/labs-dd04033db23a58f3.js"],"/page-types/[pageTypeId]":[c,n,u,h,l,s,t,b,f,o,a,e,k,j,r,m,"static/chunks/pages/page-types/[pageTypeId]-669d5479e81b638b.js"],"/slices":[c,i,s,b,a,d,j,"static/css/efa5152b7c0f35c0.css","static/chunks/pages/slices-bf63f937b184b470.js"],"/slices/[lib]/[sliceName]/[variation]":[c,i,n,u,h,l,s,t,b,f,a,k,d,"static/css/cdee5b195444f185.css","static/chunks/pages/slices/[lib]/[sliceName]/[variation]-e6bc7cc6186d6a0f.js"],"/slices/[lib]/[sliceName]/[variation]/simulator":[i,"static/chunks/72585f70-28b4d7d5384b3703.js","static/chunks/429-1137c819c2bf6b66.js","static/chunks/pages/slices/[lib]/[sliceName]/[variation]/simulator-f237aaa755dc9a99.js"],sortedPages:["/","/_app","/_error","/changelog","/changes","/custom-types","/custom-types/[customTypeId]","/labs","/page-types/[pageTypeId]","/slices","/slices/[lib]/[sliceName]/[variation]","/slices/[lib]/[sliceName]/[variation]/simulator"]}}("static/chunks/397-e6c340070a3bcb41.js","static/chunks/59b4e022-ef680789f7cc9b11.js","static/chunks/34-50c64778da33cff6.js","static/chunks/647-4379a741c8d85d9e.js","static/chunks/183-4ea255b867ff171b.js","static/chunks/c8eae200-966ce352f7b5d2b9.js","static/chunks/50-586dc7ab5e584e76.js","static/chunks/658-8231c0b729e0124a.js","static/chunks/f36c6662-1f3a854183168b10.js","static/chunks/4c744e84-480e426e4b1cfef3.js","static/chunks/065a3ddb-9a38ca0d60f0bf2f.js","static/chunks/1cc2734a-09fb3b997ad1eb70.js","static/chunks/349-7118116b93278f73.js","static/chunks/630-eae75e90b30f201a.js","static/chunks/907-445266211c48b1a5.js","static/chunks/248-a9c33f7fbe2da2f1.js","static/css/4e475d945cf8a890.css","static/chunks/422-c9192a1dbdd2ae0e.js","static/chunks/489-a046ae0fa4f74435.js","static/css/56f2a6684a524374.css"),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB();
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[34],{62434:function(e,t,n){"use strict";n.d(t,{Zb:function(){return c},T$:function(){return m},eW:function(){return _},ZB:function(){return u},Lm:function(){return C}});var o=n(52322),r=n(50002),i=n(14226),a=n(6277),l=n(2784),d=n(67968),s=n.n(d);let c=e=>{let{checked:t=!1,size:n="medium",variant:i="solid",interactive:d,disabled:c,onClick:u,href:m,component:_="a",replace:C,...h}=e,x={...h,className:(0,a.W)(s().root,s()["size-".concat(n)],s()[i],{[s().interactive]:e.interactive}),"data-state":!0===t?"checked":void 0,"data-disabled":!0===e.disabled?"":void 0};return!0===e.interactive&&void 0===e.href?(0,o.jsx)("div",{...x,onClick:t=>{if(!0===e.disabled||void 0===e.onClick)return;let n=t.target;(0,r.JY)(n)===t.currentTarget&&e.onClick(t)},tabIndex:!0===e.disabled?void 0:0}):!0===e.interactive?(0,l.createElement)(_,{...x,href:e.href,onClick:e=>{let t=e.target;(0,r.JY)(t)!==e.currentTarget&&e.preventDefault()},..."a"===_?{}:{replace:e.replace}}):(0,o.jsx)("div",{...x})},u=e=>{let{className:t,component:n="img",overlay:r,...i}=e;return(0,o.jsxs)("div",{className:s().media,children:[(0,l.createElement)(n,{...i,className:(0,a.W)(s()["mediaComponent-".concat(n)],t)}),r?(0,o.jsx)("div",{className:s().mediaOverlay,children:r}):void 0]})},m=e=>(0,o.jsx)("div",{...e,className:s().actions}),_=e=>{let{action:t,loading:n=!1,startIcon:r,subtitle:a,title:l,error:d=!1,...c}=e,u=d?"tomato11":"grey11";return(0,o.jsxs)("div",{...c,className:s().footer,children:[(r||n)&&(0,o.jsxs)("div",{className:s().startIconBox,children:[n&&(0,o.jsx)(i.bg,{color:"grey11"}),!n&&r&&(0,o.jsx)(i.aX,{name:r,size:"small",color:u})]}),(0,o.jsxs)("div",{className:s().footerTexts,children:[(0,o.jsx)(i.bL,{component:"span",noWrap:!0,variant:"bold",children:l}),(0,o.jsx)(i.bL,{color:u,component:"span",noWrap:!0,variant:"small",children:a})]}),t]})},C=e=>{let{children:t,...n}=e;return(0,o.jsx)("div",{...n,className:s().status,children:(0,o.jsx)(i.bL,{align:"center",color:"inherit",component:"span",noWrap:!0,variant:"smallBold",children:t})})}},99195:function(e,t,n){"use strict";n.d(t,{O:function(){return l}});var o=n(52322),r=n(14226),i=n(56448),a=n(93671);let l=e=>{let{badgeColor:t,badgeTitle:n,tooltipContent:l}=function(e){let t=d[e.modelType];switch(e.modelStatus){case i.GJ.New:return{badgeColor:"green",badgeTitle:"New",tooltipContent:"This ".concat(t," exists only locally. Upon sync, it will be pushed to your remote repository.")};case i.GJ.Modified:return{badgeColor:"amber",badgeTitle:"Modified",tooltipContent:"This ".concat(t," has been modified locally. Upon sync, changes will be pushed to your remote repository.")};case i.GJ.Synced:return{badgeColor:"purple",badgeTitle:"Synced",tooltipContent:"This ".concat(t," is in sync with the remote repository.")};case i.GJ.Deleted:return{badgeColor:"tomato",badgeTitle:"Deleted",tooltipContent:"This ".concat(t," has been deleted locally.")};case i.GJ.Unknown:if(!e.isOnline)return{badgeColor:"grey",badgeTitle:"Unknown",tooltipContent:"Data from the remote repository could not be fetched (no internet connection)."};if(e.authStatus===a.t.UNAUTHENTICATED)return{badgeColor:"grey",badgeTitle:"Unknown",tooltipContent:"Data from the remote repository could not be fetched (not connected to Prismic)."};default:return{badgeColor:"grey",badgeTitle:"Unknown",tooltipContent:"Data from the remote repository could not be fetched (unknown error)."}}}(e);return(0,o.jsx)(r.c3,{content:l,side:"bottom",children:(0,o.jsx)(r.m,{color:t,title:n})})},d={CustomType:"type",Slice:"slice"}},51507:function(e,t,n){"use strict";n.d(t,{b:function(){return h}});var o=n(52322),r=n(14226),i=n(39097),a=n.n(i),l=n(62434),d=n(63908),s=n(99195),c=n(27763);let u=e=>(0,o.jsx)("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:(0,o.jsx)("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M4 5.5C4 4.67157 4.67157 4 5.5 4H18.5C19.3284 4 20 4.67157 20 5.5V12.4413C20 12.4512 19.9997 12.461 19.9991 12.4707C20.0072 12.6083 19.9586 12.7485 19.8536 12.8536C19.6583 13.0488 19.3417 13.0488 19.1464 12.8536L16.3536 10.0607C16.1583 9.8654 15.8417 9.8654 15.6464 10.0607L11.8536 13.8536C11.6583 14.0488 11.3417 14.0488 11.1464 13.8536L9.35355 12.0607C9.15829 11.8654 8.84171 11.8654 8.64645 12.0607L5 15.7071V18.5C5 18.7761 5.22386 19 5.5 19H12.5C12.7761 19 13 19.2239 13 19.5C13 19.7761 12.7761 20 12.5 20H5.5C4.67157 20 4 19.3284 4 18.5V15.5003V15.4997V5.5ZM11.5 12.7929L14.9393 9.35355C15.5251 8.76777 16.4749 8.76777 17.0607 9.35355L19 11.2929V5.5C19 5.22386 18.7761 5 18.5 5H5.5C5.22386 5 5 5.22386 5 5.5V14.2929L7.93934 11.3536C8.52513 10.7678 9.47487 10.7678 10.0607 11.3536L11.5 12.7929ZM16.5 13C16.7761 13 17 13.2239 17 13.5V16H19.5C19.7761 16 20 16.2239 20 16.5C20 16.7761 19.7761 17 19.5 17H17V19.5C17 19.7761 16.7761 20 16.5 20C16.2239 20 16 19.7761 16 19.5V17H13.5C13.2239 17 13 16.7761 13 16.5C13 16.2239 13.2239 16 13.5 16H16V13.5C16 13.2239 16.2239 13 16.5 13Z",fill:"currentColor"})}),m=e=>({hash:e.hash}),_=e=>e?Object.entries(e).reduce((e,t)=>{let[n,o]=t;return o.hash?{...e,[n]:{...o,...m(o)}}:e},{}):{},C={build:e=>({...e,screenshots:_(e.screenshots)}),variation(e,t){if(e.model.variations.length)return t?e.model.variations.find(e=>e.id===t):e.model.variations[0]}},h=e=>{let t;let{action:n,isDeleted:i=!1,onUpdateScreenshot:m,selected:_=!1,slice:h,variant:p,variationId:b}=e,f=C.variation(h,b);if(!f)return null;let g=(0,d.d7)(h,f),j=!i&&!!m,y="outlined"===p,k=void 0!==b;return t="selection"===e.mode?{disabled:i,interactive:!0,onClick:()=>{e.onSelectedChange(!_)}}:i?{interactive:!1}:{component:a(),href:c.Y.getBuilderPagePathname({libraryName:h.href,sliceName:h.model.name,variationId:f.id}),interactive:!0,replace:e.replace},(0,o.jsxs)(l.Zb,{"aria-label":"".concat(h.model.name," ").concat(f.name," slice card"),checked:_,"data-testid":"shared-slice-card",...t,..."outlined"===p?{size:"small",variant:"outlined"}:{},children:[void 0!==g?(0,o.jsx)(l.ZB,{alt:"Preview image",overlay:j&&!y?(0,o.jsx)(r.D,{alignItems:"center",justifyContent:"center",children:(0,o.jsx)(x,{onClick:m})}):void 0,src:g}):(0,o.jsx)(l.ZB,{component:"div",children:(0,o.jsxs)(r.D,{alignItems:"center",flexDirection:"column",gap:8,justifyContent:"center",children:[(0,o.jsx)(r.bL,{color:"grey11",component:"span",children:"No screenshot available"}),j&&!y?(0,o.jsx)(x,{onClick:m}):void 0]})}),(0,o.jsx)(l.eW,{action:"checkbox"===n.type&&"selection"===e.mode?(0,o.jsx)("div",{onClick:e=>e.stopPropagation(),children:(0,o.jsx)(r.U,{checked:_,disabled:i,onCheckedChange:e.onSelectedChange})}):"menu"===n.type?(0,o.jsxs)(r.ar,{modal:!0,children:[(0,o.jsx)(r.av,{disabled:i,children:(0,o.jsx)(r.aZ,{hiddenLabel:"Slice actions",icon:"moreVert"})}),(0,o.jsxs)(r.as,{align:"end","data-testid":"slice-action-icon-dropdown",children:[j&&y?(0,o.jsx)(r.at,{onSelect:m,startIcon:(0,o.jsx)(u,{}),children:"Update screenshot"}):void 0,(0,o.jsx)(r.at,{onSelect:n.onRename,startIcon:(0,o.jsx)(r.aX,{name:"edit"}),children:"Rename"}),!0===n.removeDisabled&&k?(0,o.jsx)(r.c3,{content:"The slice needs to have at least one variation.",side:"bottom",stableMount:!0,children:(0,o.jsx)(v,{disabled:!0,onSelect:n.onRemove})}):(0,o.jsx)(v,{disabled:!0===n.removeDisabled,onSelect:n.onRemove})]})]}):"remove"===n.type?(0,o.jsx)(r.aZ,{icon:"close",onClick:()=>!i&&n.onRemove(),hiddenLabel:"Remove slice"}):"status"===n.type?(0,o.jsx)(s.O,{authStatus:n.authStatus,isOnline:n.isOnline,modelStatus:n.modelStatus,modelType:"Slice"}):void 0,subtitle:(0,o.jsx)(o.Fragment,{children:k?f.id:"".concat(h.model.variations.length," variation").concat(h.model.variations.length>1?"s":"")}),title:k?f.name:h.model.name}),j&&!k&&(0,d.cx)(h)>0?(0,o.jsx)(l.Lm,{children:"Missing screenshot"}):void 0]})},x=e=>(0,o.jsx)(r.E,{onClick:e.onClick,renderStartIcon:()=>(0,o.jsx)(u,{color:r.t.color.grey11}),color:"grey",children:"Update screenshot"}),v=e=>(0,o.jsx)(r.at,{...e,color:"tomato",startIcon:(0,o.jsx)(r.aX,{name:"delete"}),children:"Delete"})},27763:function(e,t,n){"use strict";n.d(t,{Y:function(){return o}});let o={getBuilderPagePathname:e=>"/slices/".concat(e.libraryName.replaceAll("/","--"),"/").concat(e.sliceName,"/").concat(e.variationId)}},30527:function(e,t,n){"use strict";n.d(t,{Z:function(){return s},W:function(){return d}});var o=n(52322),r=n(2784),i=n(75289);let a=e=>{let{bg:t,background:n,sx:r,withRadius:a,radius:l,children:d}=e;return(0,o.jsx)(i.xu,{sx:{p:4,bg:t||n,...a?{borderBottomLeftRadius:l,borderBottomRightRadius:l}:null,...r},children:d})},l=(0,r.createContext)("6px"),d=()=>(0,r.useContext)(l),s=e=>{let{Header:t=null,SubHeader:n=null,Body:r=null,Footer:d=null,borderFooter:s=!1,radius:c="6px",bodySx:u={},footerSx:m={},sx:_=null,bg:C,background:h,children:x,...v}=e;return(0,o.jsx)(l.Provider,{value:c,children:(0,o.jsxs)(i.Zb,{sx:{border:e=>{var t;return"1px solid ".concat(String(null===(t=e.colors)||void 0===t?void 0:t.borders))},borderRadius:c,..._},...v,children:[t||null,n||null,(0,o.jsxs)(a,{bg:C,background:h,sx:u,withRadius:!d,children:[r?(0,o.jsx)(r,{}):null,x||null]}),d?(0,o.jsx)(a,{bg:C,background:h,sx:{...s?{borderTop:e=>{let{colors:t}=e;return"1px solid ".concat(String(null==t?void 0:t.borders))}}:null,...m},radius:c,withRadius:!0,children:"object"==typeof d?d:(0,o.jsx)(d,{})}):null]})})}},7974:function(e,t,n){"use strict";n.d(t,{Sn:function(){return l},lS:function(){return o},nG:function(){return r},pq:function(){return d},rd:function(){return a},xo:function(){return i}});let o=["components","update","insert"],r=["png","jpg","jpeg"],i=/^[A-Za-z0-9]+(?:_[A-Za-z0-9]+)*$/,a="placeholders/What_are_Slices_mrvome",l="SM_HELP_VIDEOS/mock_data",d="slice-machine-simulator"},67968:function(e){e.exports={flex:"Card_flex__opby1",grid:"Card_grid__VAvIS",column:"Card_column__W4ACG Card_flex__opby1",root:"Card_root__YVuvU Card_column__W4ACG Card_flex__opby1","size-small":"Card_size-small__aIlxd","size-medium":"Card_size-medium__xegz0",solid:"Card_solid__GNGar",outlined:"Card_outlined__W_dxI",interactive:"Card_interactive__rXw5L",media:"Card_media__l0kHL Card_column__W4ACG Card_flex__opby1","mediaComponent-div":"Card_mediaComponent-div__Y2_PZ Card_grid__VAvIS","mediaComponent-img":"Card_mediaComponent-img__ezOTu",mediaOverlay:"Card_mediaOverlay__Aa__Q Card_grid__VAvIS",nonMedia:"Card_nonMedia__Fv3Mz Card_flex__opby1",actions:"Card_actions__XdhOt Card_nonMedia__Fv3Mz Card_flex__opby1",footer:"Card_footer__U0HS1 Card_nonMedia__Fv3Mz Card_flex__opby1",footerTexts:"Card_footerTexts__rTXup Card_column__W4ACG Card_flex__opby1",status:"Card_status__PNN2a Card_column__W4ACG Card_flex__opby1",startIconBox:"Card_startIconBox__1_L4u"}}}]);