@epic-web/workshop-app 5.12.2 → 5.13.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 (62) hide show
  1. package/build/client/assets/{_exerciseNumber-B5x3u5o0.js → _exerciseNumber-Bd4c2v-C.js} +2 -2
  2. package/build/client/assets/{_exerciseNumber-B5x3u5o0.js.map → _exerciseNumber-Bd4c2v-C.js.map} +1 -1
  3. package/build/client/assets/{_exerciseNumber_.finished-CWHBWFYP.js → _exerciseNumber_.finished-LvfViAKb.js} +2 -2
  4. package/build/client/assets/{_exerciseNumber_.finished-CWHBWFYP.js.map → _exerciseNumber_.finished-LvfViAKb.js.map} +1 -1
  5. package/build/client/assets/{_layout-D7PSWvDV.js → _layout-DhhhwkhJ.js} +2 -2
  6. package/build/client/assets/{_layout-D7PSWvDV.js.map → _layout-DhhhwkhJ.js.map} +1 -1
  7. package/build/client/assets/{_layout-B5GBAg5P.js → _layout-cO4Dvl1j.js} +2 -2
  8. package/build/client/assets/_layout-cO4Dvl1j.js.map +1 -0
  9. package/build/client/assets/{app-C2OvdXoM.js → app-DK_pEo6e.js} +2 -2
  10. package/build/client/assets/{app-C2OvdXoM.js.map → app-DK_pEo6e.js.map} +1 -1
  11. package/build/client/assets/{diff-BIJG7lM0.js → diff-BrUTVi14.js} +2 -2
  12. package/build/client/assets/diff-BrUTVi14.js.map +1 -0
  13. package/build/client/assets/{diff-BLwCINNG.js → diff-DI-wBaTF.js} +2 -2
  14. package/build/client/assets/{diff-BLwCINNG.js.map → diff-DI-wBaTF.js.map} +1 -1
  15. package/build/client/assets/{epic-video-BN9tH2d3.js → epic-video-DoUlMEIW.js} +2 -2
  16. package/build/client/assets/{epic-video-BN9tH2d3.js.map → epic-video-DoUlMEIW.js.map} +1 -1
  17. package/build/client/assets/{finished-DCXZj8Z6.js → finished-y90Pn48k.js} +2 -2
  18. package/build/client/assets/{finished-DCXZj8Z6.js.map → finished-y90Pn48k.js.map} +1 -1
  19. package/build/client/assets/index-BOO5UotZ.js +36 -0
  20. package/build/client/assets/index-BOO5UotZ.js.map +1 -0
  21. package/build/client/assets/{index-URcvFBYJ.js → index-CxEnb-w2.js} +2 -2
  22. package/build/client/assets/index-CxEnb-w2.js.map +1 -0
  23. package/build/client/assets/{index-I2Jm_PoG.js → index-De6oiBJI.js} +2 -2
  24. package/build/client/assets/{index-I2Jm_PoG.js.map → index-De6oiBJI.js.map} +1 -1
  25. package/build/client/assets/{loading-ZSC9wgHC.js → loading-D4V_nJZr.js} +2 -2
  26. package/build/client/assets/{loading-ZSC9wgHC.js.map → loading-D4V_nJZr.js.map} +1 -1
  27. package/build/client/assets/{login-RlImW-EE.js → login-DiEHnGfv.js} +2 -2
  28. package/build/client/assets/{login-RlImW-EE.js.map → login-DiEHnGfv.js.map} +1 -1
  29. package/build/client/assets/{manifest-022c9919.js → manifest-44a29362.js} +1 -1
  30. package/build/client/assets/{mdx-wFsONSmT.js → mdx-Ce3knRHx.js} +2 -2
  31. package/build/client/assets/{mdx-wFsONSmT.js.map → mdx-Ce3knRHx.js.map} +1 -1
  32. package/build/client/assets/{onboarding-y1OmFtYT.js → onboarding-Dnb9KzTs.js} +2 -2
  33. package/build/client/assets/{onboarding-y1OmFtYT.js.map → onboarding-Dnb9KzTs.js.map} +1 -1
  34. package/build/client/assets/{online-DZEJ9mQ4.js → online-BrcRwzQC.js} +2 -2
  35. package/build/client/assets/{online-DZEJ9mQ4.js.map → online-BrcRwzQC.js.map} +1 -1
  36. package/build/client/assets/{presence-BPdQqqxh.js → presence-Dmt5LCeW.js} +2 -2
  37. package/build/client/assets/{presence-BPdQqqxh.js.map → presence-Dmt5LCeW.js.map} +1 -1
  38. package/build/client/assets/{preview-DwJJV8IU.js → preview-BUkOZv9x.js} +2 -2
  39. package/build/client/assets/{preview-DwJJV8IU.js.map → preview-BUkOZv9x.js.map} +1 -1
  40. package/build/client/assets/{product-DD8nUALO.js → product-CleOH5Nn.js} +2 -2
  41. package/build/client/assets/{product-DD8nUALO.js.map → product-CleOH5Nn.js.map} +1 -1
  42. package/build/client/assets/{revalidation-ws-BIizeOeQ.js → revalidation-ws-CibzUlFP.js} +2 -2
  43. package/build/client/assets/{revalidation-ws-BIizeOeQ.js.map → revalidation-ws-CibzUlFP.js.map} +1 -1
  44. package/build/client/assets/{root-D2jqGwJl.js → root-BOerY_70.js} +3 -3
  45. package/build/client/assets/{root-D2jqGwJl.js.map → root-BOerY_70.js.map} +1 -1
  46. package/build/client/assets/{set-playground-BoPKA2de.js → set-playground-DBPp1Pek.js} +2 -2
  47. package/build/client/assets/set-playground-DBPp1Pek.js.map +1 -0
  48. package/build/client/assets/tailwind-Bcxzac75.css +1 -0
  49. package/build/client/assets/{test-BqhhxMae.js → test-DGBB06nI.js} +2 -2
  50. package/build/client/assets/{test-BqhhxMae.js.map → test-DGBB06nI.js.map} +1 -1
  51. package/build/client/assets/{tests-9K325XZ-.js → tests-B6AwzXv3.js} +2 -2
  52. package/build/client/assets/{tests-9K325XZ-.js.map → tests-B6AwzXv3.js.map} +1 -1
  53. package/build/server/index.js +8 -409
  54. package/build/server/index.js.map +1 -1
  55. package/package.json +3 -6
  56. package/build/client/assets/_layout-B5GBAg5P.js.map +0 -1
  57. package/build/client/assets/diff-BIJG7lM0.js.map +0 -1
  58. package/build/client/assets/index-Ba7zHVvt.js +0 -36
  59. package/build/client/assets/index-Ba7zHVvt.js.map +0 -1
  60. package/build/client/assets/index-URcvFBYJ.js.map +0 -1
  61. package/build/client/assets/set-playground-BoPKA2de.js.map +0 -1
  62. package/build/client/assets/tailwind-4klXLdJc.css +0 -1
@@ -5,13 +5,13 @@ import { RemixServer, Link, useRouteError, useParams, isRouteErrorResponse, useN
5
5
  import { isbot } from "isbot";
6
6
  import { renderToPipeableStream, renderToStaticMarkup } from "react-dom/server";
7
7
  import path from "node:path";
8
- import { makeSingletonCache, cachified, deleteCache, compiledCodeCache, diffFilesCache, diffCodeCache, shouldForceFresh, fsCache, getAllFileCacheEntries, ogCache } from "@epic-web/workshop-utils/cache.server";
8
+ import { makeSingletonCache, cachified, deleteCache, compiledCodeCache, shouldForceFresh, fsCache, getAllFileCacheEntries, ogCache } from "@epic-web/workshop-utils/cache.server";
9
9
  import { getWorkshopConfig } from "@epic-web/workshop-utils/config.server";
10
10
  import { getAuthInfo, getPreferences, readOnboardingData, requireAuthInfo, deleteDb, setPreferences, PlayerPreferencesSchema, setAuthInfo, markOnboardingVideoWatched } from "@epic-web/workshop-utils/db.server";
11
11
  import { getUserInfo, userHasAccessToWorkshop, getProgress, updateProgress, getEpicVideoInfos } from "@epic-web/workshop-utils/epic-api.server";
12
12
  import { getUserId, getSetClientIdCookieHeader } from "@epic-web/workshop-utils/user.server";
13
13
  import { z } from "zod";
14
- import { getApps, getExercises, getPlaygroundAppName, extractNumbersAndTypeFromAppNameOrPath, getAppFromFile, getAppByName, isProblemApp, isPlaygroundApp, isExerciseStepApp, getExercise, isSolutionApp, isExampleApp, getRelativePath as getRelativePath$1, workshopRoot, modifiedTimes, getForceFreshForDir, setPlayground, requireExerciseApp, requireExercise, getExerciseApp, getAppDisplayName, getNextExerciseApp, getPrevExerciseApp, getAppPageRoute, getWorkshopFinished, getWorkshopInstructions } from "@epic-web/workshop-utils/apps.server";
14
+ import { getApps, getExercises, getPlaygroundAppName, extractNumbersAndTypeFromAppNameOrPath, getAppFromFile, getAppByName, isProblemApp, isPlaygroundApp, isExerciseStepApp, getExercise, isSolutionApp, isExampleApp, getRelativePath as getRelativePath$1, workshopRoot, setPlayground, requireExerciseApp, requireExercise, getExerciseApp, getAppDisplayName, getNextExerciseApp, getPrevExerciseApp, getAppPageRoute, getWorkshopFinished, getWorkshopInstructions } from "@epic-web/workshop-utils/apps.server";
15
15
  import { getEnv } from "@epic-web/workshop-utils/env.server";
16
16
  import { makeTimings, getServerTimeHeader, combineServerTimings, time } from "@epic-web/workshop-utils/timing.server";
17
17
  import { checkConnectionCached, dayjs } from "@epic-web/workshop-utils/utils.server";
@@ -47,7 +47,7 @@ import etag from "etag";
47
47
  import fsExtra from "fs-extra";
48
48
  import mimeTypes from "mime-types";
49
49
  import fs from "fs";
50
- import { getDirModifiedTime, modifiedMoreRecentlyThan } from "@epic-web/workshop-utils/modified-time.server";
50
+ import { getDirModifiedTime } from "@epic-web/workshop-utils/modified-time.server";
51
51
  import * as esbuild from "esbuild";
52
52
  import { ElementScrollRestoration } from "@epic-web/restore-scroll";
53
53
  import RealMuxPlayer, { MinResolution, MaxResolution } from "@mux/mux-player-react";
@@ -56,14 +56,11 @@ import os from "os";
56
56
  import shellQuote from "shell-quote";
57
57
  import { LRUCache } from "lru-cache";
58
58
  import * as mdxBundler from "mdx-bundler/client/index.js";
59
+ import { getDiffCode, getDiffFiles } from "@epic-web/workshop-utils/diff.server";
59
60
  import * as Select from "@radix-ui/react-select";
60
- import { compileMarkdownString } from "@epic-web/workshop-utils/compile-mdx.server";
61
- import { execa } from "execa";
62
- import ignore from "ignore";
63
- import parseGitDiff from "parse-git-diff";
64
- import { bundledLanguagesInfo } from "shiki/langs";
65
61
  import * as Popover from "@radix-ui/react-popover";
66
62
  import { stopPort, runAppDev, waitOnApp, closeProcess, isAppRunning, isPortAvailable, getTestProcessEntry, isTestRunning, clearTestProcessEntry, runAppTests, getProcesses } from "@epic-web/workshop-utils/process-manager.server";
63
+ import { compileMarkdownString } from "@epic-web/workshop-utils/compile-mdx.server";
67
64
  import * as Tabs from "@radix-ui/react-tabs";
68
65
  import * as Accordion from "@radix-ui/react-accordion";
69
66
  import AnsiToHTML from "ansi-to-html";
@@ -925,7 +922,7 @@ const route45 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.definePrope
925
922
  useTheme
926
923
  }, Symbol.toStringTag, { value: "Module" }));
927
924
  const appStylesheetUrl = "/assets/app-DGPT3Jy6.css";
928
- const tailwindStylesheetUrl = "/assets/tailwind-4klXLdJc.css";
925
+ const tailwindStylesheetUrl = "/assets/tailwind-Bcxzac75.css";
929
926
  const cookieName = "EpicShop_confetti";
930
927
  function getConfetti(request) {
931
928
  const cookieHeader = request.headers.get("cookie");
@@ -5789,404 +5786,6 @@ function NavChevrons({
5789
5786
  ) : null
5790
5787
  ] });
5791
5788
  }
5792
- const epicshopTempDir = path$1.join(os.tmpdir(), "epicshop");
5793
- const isDeployed = ENV.EPICSHOP_DEPLOYED;
5794
- const diffTmpDir = path$1.join(epicshopTempDir, "diff");
5795
- function diffPathToRelative(filePath) {
5796
- let normalizedPath = path$1.normalize(filePath.replace(/^("|')|("|')$/g, ""));
5797
- if (normalizedPath.startsWith("a\\") || normalizedPath.startsWith("b\\") || normalizedPath.startsWith("a/") || normalizedPath.startsWith("b/")) {
5798
- normalizedPath = normalizedPath.slice(2);
5799
- }
5800
- const [workshopRootDirname, appId, id, ...relativePath] = normalizedPath.replace(
5801
- process.platform === "win32" || normalizedPath.startsWith(path$1.sep) ? `${diffTmpDir}${path$1.sep}` : `${diffTmpDir.slice(1)}${path$1.sep}`,
5802
- ""
5803
- ).split(path$1.sep);
5804
- return relativePath.join(path$1.sep);
5805
- }
5806
- function getLanguage(ext) {
5807
- var _a;
5808
- return ((_a = bundledLanguagesInfo.find((l) => {
5809
- var _a2;
5810
- return l.id === ext || ((_a2 = l.aliases) == null ? void 0 : _a2.includes(ext));
5811
- })) == null ? void 0 : _a.id) ?? "text";
5812
- }
5813
- function getFileCodeblocks(file, filePathApp1, filePathApp2, type) {
5814
- if (!file.chunks.length) {
5815
- return [
5816
- `<p className="m-0 p-4 border-b text-muted-foreground">No changes</p>`
5817
- ];
5818
- }
5819
- const filepath = diffPathToRelative(
5820
- file.type === "RenamedFile" ? file.pathAfter : file.path
5821
- );
5822
- const extension = path$1.extname(filepath).slice(1);
5823
- const lang = getLanguage(extension);
5824
- const pathToCopy = file.type === "RenamedFile" ? file.pathBefore : file.path;
5825
- const relativePath = diffPathToRelative(pathToCopy);
5826
- const markdownLines = [];
5827
- for (const chunk of file.chunks) {
5828
- let launchEditor2 = function(appNum, line) {
5829
- if (isDeployed) {
5830
- if (type === "DeletedFile" && appNum === 2) return "";
5831
- if (type === "AddedFile" && appNum === 1) return "";
5832
- }
5833
- const label = type === "AddedFile" && appNum === 1 || type === "DeletedFile" && appNum === 2 ? `CREATE in APP ${appNum}` : `OPEN in APP ${appNum}`;
5834
- const file2 = JSON.stringify(appNum === 1 ? filePathApp1 : filePathApp2);
5835
- const fixedTitle = getRelativePath$1(file2);
5836
- return `
5837
- <LaunchEditor file=${file2} line={${line}}>
5838
- <span title="${fixedTitle}" className="${launchEditorClassName}">${label}</span>
5839
- </LaunchEditor>`;
5840
- };
5841
- const removedLineNumbers = [];
5842
- const addedLineNumbers = [];
5843
- const lines = [];
5844
- let toStartLine = 0;
5845
- let startLine = 1;
5846
- if (chunk.type === "BinaryFilesChunk") {
5847
- lines.push(
5848
- type === "AddedFile" ? `Binary file added` : type === "DeletedFile" ? "Binary file deleted" : "Binary file changed"
5849
- );
5850
- } else {
5851
- startLine = chunk.type === "Chunk" ? chunk.fromFileRange.start : chunk.type === "CombinedChunk" ? chunk.fromFileRangeA.start : 1;
5852
- toStartLine = chunk.toFileRange.start;
5853
- for (let lineNumber = 0; lineNumber < chunk.changes.length; lineNumber++) {
5854
- const change = chunk.changes[lineNumber];
5855
- if (!change) continue;
5856
- lines.push(change.content);
5857
- switch (change.type) {
5858
- case "AddedLine": {
5859
- addedLineNumbers.push(startLine + lineNumber);
5860
- break;
5861
- }
5862
- case "DeletedLine": {
5863
- removedLineNumbers.push(startLine + lineNumber);
5864
- break;
5865
- }
5866
- }
5867
- }
5868
- }
5869
- const params = [
5870
- ["filename", relativePath.replace(/\\/g, "\\\\")],
5871
- ["start", startLine.toString()],
5872
- removedLineNumbers.length ? ["remove", removedLineNumbers.join(",")] : null,
5873
- addedLineNumbers.length ? ["add", addedLineNumbers.join(",")] : null
5874
- ].filter(Boolean).map(([key, value]) => `${key}=${value}`).join(" ");
5875
- const launchEditorClassName = "border hover:bg-foreground/20 rounded px-2 py-0.5 font-mono text-xs font-semibold";
5876
- markdownLines.push(`
5877
- <div className="relative">
5878
-
5879
- \`\`\`${lang} ${params}
5880
- ${lines.join("\n")}
5881
- \`\`\`
5882
-
5883
- <div className="flex gap-4 absolute top-1 right-3 items-center">
5884
- ${launchEditor2(1, startLine)}
5885
- <div className="display-alt-down flex gap-2">
5886
- <LaunchEditor file=${JSON.stringify(
5887
- filePathApp1
5888
- )} syncTo={{file: ${JSON.stringify(filePathApp2)}}}>
5889
- <span className="block ${launchEditorClassName}">
5890
- <Icon name="ArrowLeft" title="Copy app 2 file to app 1" />
5891
- </span>
5892
- </LaunchEditor>
5893
- <LaunchEditor file=${JSON.stringify(
5894
- filePathApp2
5895
- )} syncTo={{file: ${JSON.stringify(filePathApp1)}}}>
5896
- <span className="block ${launchEditorClassName}">
5897
- <Icon name="ArrowRight" title="Copy app 1 file to app 2" />
5898
- </span>
5899
- </LaunchEditor>
5900
- </div>
5901
- ${launchEditor2(2, toStartLine)}
5902
- </div>
5903
-
5904
- </div>
5905
- `);
5906
- }
5907
- return markdownLines;
5908
- }
5909
- const DEFAULT_IGNORE_PATTERNS = [
5910
- "**/README.*",
5911
- "**/package-lock.json",
5912
- "**/.DS_Store",
5913
- "**/.vscode",
5914
- "**/.idea",
5915
- "**/.git",
5916
- "**/*.db",
5917
- "**/epicshop/**"
5918
- ];
5919
- async function copyUnignoredFiles(srcDir, destDir, ignoreList) {
5920
- const key = `COPY_${srcDir}__${destDir}__${ignoreList.join("_")}`;
5921
- await cachified({
5922
- key,
5923
- cache: diffCodeCache,
5924
- forceFresh: getForceFreshForDir(diffCodeCache.get(key), srcDir),
5925
- async getFreshValue() {
5926
- const ig = ignore().add(ignoreList);
5927
- await fsExtra.remove(destDir);
5928
- await fsExtra.copy(srcDir, destDir, {
5929
- filter: async (file) => {
5930
- if (file === srcDir) return true;
5931
- return !ig.ignores(path$1.relative(srcDir, file));
5932
- }
5933
- });
5934
- }
5935
- });
5936
- }
5937
- async function prepareForDiff(app1, app2) {
5938
- const id = Math.random().toString(36).slice(2);
5939
- const app1CopyPath = path$1.join(
5940
- diffTmpDir,
5941
- path$1.basename(workshopRoot),
5942
- app1.name,
5943
- id
5944
- );
5945
- const app2CopyPath = path$1.join(
5946
- diffTmpDir,
5947
- path$1.basename(workshopRoot),
5948
- app2.name,
5949
- id
5950
- );
5951
- const comparePkgJson = (pkg1, pkg2) => {
5952
- const { name, ...rest1 } = pkg1;
5953
- const { name: name2, ...rest2 } = pkg2;
5954
- return JSON.stringify(rest1) === JSON.stringify(rest2);
5955
- };
5956
- const app1PkgJson = app1.dev.type === "script" ? await fsExtra.readJSON(path$1.join(app1.fullPath, "package.json")).catch(() => ({})) : {};
5957
- const app2PkgJson = app1.dev.type === "script" ? await fsExtra.readJSON(path$1.join(app2.fullPath, "package.json")).catch(() => ({})) : {};
5958
- const pkgJsonIgnore = comparePkgJson(app1PkgJson, app2PkgJson) ? ["package.json"] : [];
5959
- const workshopIgnore = [
5960
- ...await getDiffIgnore(path$1.join(workshopRoot, ".gitignore")),
5961
- ...await getDiffIgnore(
5962
- path$1.join(workshopRoot, "epicshop", ".diffignore")
5963
- )
5964
- ];
5965
- await Promise.all([
5966
- copyUnignoredFiles(app1.fullPath, app1CopyPath, [
5967
- ...DEFAULT_IGNORE_PATTERNS,
5968
- ...pkgJsonIgnore,
5969
- ...workshopIgnore,
5970
- ...await getDiffIgnore(path$1.join(app1.fullPath, ".gitignore")),
5971
- ...await getDiffIgnore(
5972
- path$1.join(app1.fullPath, "epicshop", ".diffignore")
5973
- )
5974
- ]),
5975
- copyUnignoredFiles(app2.fullPath, app2CopyPath, [
5976
- ...DEFAULT_IGNORE_PATTERNS,
5977
- ...pkgJsonIgnore,
5978
- ...workshopIgnore,
5979
- ...await getDiffIgnore(path$1.join(app2.fullPath, ".gitignore")),
5980
- ...await getDiffIgnore(
5981
- path$1.join(app2.fullPath, "epicshop", ".diffignore")
5982
- )
5983
- ])
5984
- ]);
5985
- return { app1CopyPath, app2CopyPath };
5986
- }
5987
- async function getDiffIgnore(filePath) {
5988
- return await fsExtra.pathExists(filePath) ? fsExtra.readFile(filePath, "utf8").then(
5989
- (content) => content.split("\n").map((line) => line.trim()).filter((line) => !line.startsWith("#")).filter(Boolean)
5990
- ) : [];
5991
- }
5992
- async function getForceFreshForDiff(app1, app2, cacheEntry) {
5993
- const cacheModified = cacheEntry == null ? void 0 : cacheEntry.metadata.createdTime;
5994
- if (!cacheModified) return true;
5995
- const app1Modified = modifiedTimes.get(app1.fullPath) ?? 0;
5996
- if (app1Modified > cacheModified) return true;
5997
- const app2Modified = modifiedTimes.get(app2.fullPath) ?? 0;
5998
- if (app2Modified > cacheModified) return true;
5999
- const modifiedMoreRecently = await modifiedMoreRecentlyThan(
6000
- cacheModified,
6001
- app1.fullPath,
6002
- app2.fullPath
6003
- );
6004
- if (modifiedMoreRecently) return true;
6005
- return void 0;
6006
- }
6007
- async function getDiffFiles(app1, app2, {
6008
- forceFresh,
6009
- timings,
6010
- request
6011
- } = {}) {
6012
- const key = `${app1.relativePath}__vs__${app2.relativePath}`;
6013
- const cacheEntry = diffFilesCache.get(key);
6014
- const result = await cachified({
6015
- key,
6016
- cache: diffFilesCache,
6017
- forceFresh: forceFresh || await getForceFreshForDiff(app1, app2, cacheEntry),
6018
- timings,
6019
- request,
6020
- getFreshValue: () => getDiffFilesImpl(app1, app2)
6021
- });
6022
- return result;
6023
- }
6024
- function getAppTestFiles(app) {
6025
- return app.test.type === "browser" ? app.test.testFiles : [];
6026
- }
6027
- async function getDiffFilesImpl(app1, app2) {
6028
- if (app1.name === app2.name) {
6029
- return [];
6030
- }
6031
- const { app1CopyPath, app2CopyPath } = await prepareForDiff(app1, app2);
6032
- const { stdout: diffOutput } = await execa(
6033
- "git",
6034
- [
6035
- "diff",
6036
- "--no-index",
6037
- "--ignore-blank-lines",
6038
- "--ignore-space-change",
6039
- app1CopyPath,
6040
- app2CopyPath
6041
- ],
6042
- { cwd: diffTmpDir }
6043
- // --no-index implies --exit-code, so we need to use the error output
6044
- ).catch((e) => e);
6045
- void fsExtra.remove(app1CopyPath);
6046
- void fsExtra.remove(app2CopyPath);
6047
- const typesMap = {
6048
- ChangedFile: "modified",
6049
- AddedFile: "added",
6050
- DeletedFile: "deleted",
6051
- RenamedFile: "renamed"
6052
- };
6053
- const parsed = parseGitDiff(diffOutput, { noPrefix: true });
6054
- const testFiles = Array.from(
6055
- /* @__PURE__ */ new Set([...getAppTestFiles(app1), ...getAppTestFiles(app2)])
6056
- );
6057
- const startLine = (file) => {
6058
- const chunk = file.type === "ChangedFile" && file.chunks[0];
6059
- if (chunk) {
6060
- return chunk.type === "Chunk" ? chunk.fromFileRange.start : chunk.type === "CombinedChunk" ? chunk.fromFileRangeA.start : 1;
6061
- }
6062
- return 1;
6063
- };
6064
- return parsed.files.map((file) => ({
6065
- // prettier-ignore
6066
- status: typesMap[file.type] ?? "unknown",
6067
- path: diffPathToRelative(
6068
- file.type === "RenamedFile" ? file.pathBefore : file.path
6069
- ),
6070
- line: startLine(file)
6071
- })).filter((file) => !testFiles.includes(file.path));
6072
- }
6073
- async function getDiffCode(app1, app2, {
6074
- forceFresh,
6075
- timings,
6076
- request
6077
- } = {}) {
6078
- const key = `${app1.relativePath}__vs__${app2.relativePath}`;
6079
- const cacheEntry = diffCodeCache.get(key);
6080
- const result = await cachified({
6081
- key,
6082
- cache: diffCodeCache,
6083
- forceFresh: forceFresh || await getForceFreshForDiff(app1, app2, cacheEntry),
6084
- timings,
6085
- request,
6086
- getFreshValue: () => getDiffCodeImpl(app1, app2)
6087
- });
6088
- return result;
6089
- }
6090
- async function getDiffCodeImpl(app1, app2) {
6091
- const markdownLines = [""];
6092
- if (app1.name === app2.name) {
6093
- markdownLines.push(
6094
- '<p className="p-4 text-center">You are comparing the same app</p>'
6095
- );
6096
- const code2 = await compileMarkdownString(markdownLines.join("\n"));
6097
- return code2;
6098
- }
6099
- const { app1CopyPath, app2CopyPath } = await prepareForDiff(app1, app2);
6100
- const { stdout: diffOutput } = await execa(
6101
- "git",
6102
- [
6103
- "diff",
6104
- "--no-index",
6105
- app1CopyPath,
6106
- app2CopyPath,
6107
- "--color=never",
6108
- "--color-moved-ws=allow-indentation-change",
6109
- "--no-prefix",
6110
- "--ignore-blank-lines",
6111
- "--ignore-space-change"
6112
- ],
6113
- { cwd: diffTmpDir }
6114
- // --no-index implies --exit-code, so we need to use the error output
6115
- ).catch((e) => e);
6116
- void fsExtra.remove(app1CopyPath);
6117
- void fsExtra.remove(app2CopyPath);
6118
- const parsed = parseGitDiff(diffOutput);
6119
- if (!parsed.files.length) {
6120
- markdownLines.push(
6121
- '<div className="m-5 inline-flex items-center justify-center bg-foreground px-1 py-0.5 font-mono text-sm uppercase text-background">No changes</div>'
6122
- );
6123
- }
6124
- const app1TestFiles = getAppTestFiles(app1);
6125
- const app2TestFiles = getAppTestFiles(app2);
6126
- for (const file of parsed.files) {
6127
- const pathToCopy = file.type === "RenamedFile" ? file.pathBefore : file.path;
6128
- const relativePath = diffPathToRelative(pathToCopy);
6129
- if (app1TestFiles.includes(relativePath)) continue;
6130
- const filePathApp1 = path$1.join(app1.fullPath, relativePath);
6131
- const pathToApp2 = file.type === "RenamedFile" ? file.pathAfter : file.path;
6132
- const relativePathApp2 = diffPathToRelative(pathToApp2);
6133
- if (app2TestFiles.includes(relativePathApp2)) continue;
6134
- const filePathApp2 = path$1.join(app2.fullPath, relativePathApp2);
6135
- switch (file.type) {
6136
- case "ChangedFile": {
6137
- markdownLines.push(`
6138
-
6139
- <Accordion title=${JSON.stringify(relativePath)} variant="changed">
6140
-
6141
- ${getFileCodeblocks(file, filePathApp1, filePathApp2, file.type).join("\n")}
6142
-
6143
- </Accordion>
6144
-
6145
- `);
6146
- break;
6147
- }
6148
- case "DeletedFile": {
6149
- markdownLines.push(`
6150
- <Accordion title=${JSON.stringify(relativePath)} variant="deleted">
6151
-
6152
- ${getFileCodeblocks(file, filePathApp1, filePathApp2, file.type).join("\n")}
6153
-
6154
- </Accordion>
6155
- `);
6156
- break;
6157
- }
6158
- case "RenamedFile": {
6159
- const relativeBefore = diffPathToRelative(file.pathBefore);
6160
- const relativeAfter = diffPathToRelative(file.pathAfter);
6161
- const title = JSON.stringify(`${relativeBefore} ▶️ ${relativeAfter}`);
6162
- markdownLines.push(`
6163
- <Accordion title=${title} variant="renamed">
6164
-
6165
- ${getFileCodeblocks(file, filePathApp1, filePathApp2, file.type).join("\n")}
6166
-
6167
- </Accordion>
6168
- `);
6169
- break;
6170
- }
6171
- case "AddedFile": {
6172
- markdownLines.push(`
6173
- <Accordion title=${JSON.stringify(relativePath)} variant="added">
6174
-
6175
- ${getFileCodeblocks(file, filePathApp1, filePathApp2, file.type).join("\n")}
6176
-
6177
- </Accordion>
6178
- `);
6179
- break;
6180
- }
6181
- default: {
6182
- console.error(file);
6183
- throw new Error(`Unknown file type: ${file}`);
6184
- }
6185
- }
6186
- }
6187
- const code = await compileMarkdownString(markdownLines.join("\n"));
6188
- return code;
6189
- }
6190
5789
  const SetPlaygroundSchema = z.object({
6191
5790
  appName: z.string(),
6192
5791
  reset: z.string().nullable().optional().transform((v) => v === "true")
@@ -6358,7 +5957,7 @@ function SetAppToPlayground({ appName }) {
6358
5957
  {
6359
5958
  appName,
6360
5959
  tooltipText: "Playground is not set to the right app. Click to set Playground.",
6361
- children: /* @__PURE__ */ jsxs("span", { className: "text-foreground-destructive flex items-center justify-center gap-1 hover:underline", children: [
5960
+ children: /* @__PURE__ */ jsxs("span", { className: "flex items-center justify-center gap-1 text-foreground-destructive hover:underline", children: [
6362
5961
  /* @__PURE__ */ jsx(Icon, { name: "Unlinked", className: "animate-ping" }),
6363
5962
  " ",
6364
5963
  /* @__PURE__ */ jsx("span", { className: "uppercase", children: "Set to Playground" })
@@ -11221,7 +10820,7 @@ const route42 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.definePrope
11221
10820
  __proto__: null,
11222
10821
  loader
11223
10822
  }, Symbol.toStringTag, { value: "Module" }));
11224
- const serverManifest = { "entry": { "module": "/assets/entry.client-CQusg5Iz.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes": { "root": { "id": "root", "parentId": void 0, "path": "", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/root-D2jqGwJl.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/pe-DXT2FOp1.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/progress-bar-IswLOt8e.js", "/assets/index-CB8bjE90.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-Ba7zHVvt.js", "/assets/presence-BPdQqqxh.js", "/assets/seo-pBpFCWsy.js", "/assets/online-DZEJ9mQ4.js"], "css": [] }, "routes/$": { "id": "routes/$", "parentId": "root", "path": "*", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_-BbjJ9R-5.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/_layout": { "id": "routes/_app+/_layout", "parentId": "root", "path": void 0, "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-D7PSWvDV.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/pe-DXT2FOp1.js", "/assets/product-DD8nUALO.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-CWadM2q_.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/online-DZEJ9mQ4.js", "/assets/presence-BPdQqqxh.js", "/assets/progress-CpALgZbi.js", "/assets/index-Ba7zHVvt.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/account": { "id": "routes/_app+/account", "parentId": "routes/_app+/_layout", "path": "account", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/account-C4MWGVQU.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/app.$appName+/$": { "id": "routes/_app+/app.$appName+/$", "parentId": "routes/_app+/_layout", "path": "app/:appName/*", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/api.$": { "id": "routes/_app+/app.$appName+/api.$", "parentId": "routes/_app+/_layout", "path": "app/:appName/api/*", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/api._-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/epic_ws[.js]": { "id": "routes/_app+/app.$appName+/epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/:appName/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/index": { "id": "routes/_app+/app.$appName+/index", "parentId": "routes/_app+/_layout", "path": "app/:appName/", "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/test.$testName": { "id": "routes/_app+/app.$appName+/test.$testName", "parentId": "routes/_app+/_layout", "path": "app/:appName/test/:testName", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test._testName-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/test.epic_ws[.js]": { "id": "routes/_app+/app.$appName+/test.epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/:appName/test/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test.epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.epic_ws[.js]": { "id": "routes/_app+/app.epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/app.epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/discord": { "id": "routes/_app+/discord", "parentId": "routes/_app+/_layout", "path": "discord", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/discord-tUa_uzeh.js", "imports": ["/assets/discord-DsGCI_e6.js", "/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": [] }, "routes/_app+/exercise+/_layout": { "id": "routes/_app+/exercise+/_layout", "parentId": "routes/_app+/_layout", "path": "exercise", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-CwTidn3v.js", "imports": ["/assets/index-CGzylDPY.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber": { "id": "routes/_app+/exercise+/$exerciseNumber", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_exerciseNumber-B5x3u5o0.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-BN9tH2d3.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/mdx-wFsONSmT.js", "/assets/progress-CpALgZbi.js", "/assets/misc-D9k1wGip.js", "/assets/seo-pBpFCWsy.js", "/assets/components-DrvY4pal.js", "/assets/index-Ba7zHVvt.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber/:stepNumber", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_exerciseNumber_._stepNumber-CZKDy98j.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "path": ":type", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_layout-B5GBAg5P.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/mdx-wFsONSmT.js", "/assets/progress-CpALgZbi.js", "/assets/set-playground-BoPKA2de.js", "/assets/seo-pBpFCWsy.js", "/assets/misc-D9k1wGip.js", "/assets/epic-video-BN9tH2d3.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-Ba7zHVvt.js", "/assets/components-DrvY4pal.js", "/assets/index-CWadM2q_.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/index-D7-ne3iG.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/app": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/app", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": "app", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/app-C2OvdXoM.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/preview-DwJJV8IU.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/index-Ba7zHVvt.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/button-DhtjxLl5.js", "/assets/loading-ZSC9wgHC.js", "/assets/progress-bar-IswLOt8e.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/index": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/index", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/index-URcvFBYJ.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-D7-ne3iG.js", "/assets/misc-D9k1wGip.js", "/assets/diff-BLwCINNG.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/loading-ZSC9wgHC.js", "/assets/discord-DsGCI_e6.js", "/assets/online-DZEJ9mQ4.js", "/assets/components-DrvY4pal.js", "/assets/index-CB8bjE90.js", "/assets/set-playground-BoPKA2de.js", "/assets/tests-9K325XZ-.js", "/assets/preview-DwJJV8IU.js", "/assets/index-CWadM2q_.js", "/assets/accordion-BL_cX9y6.js", "/assets/mdx-wFsONSmT.js", "/assets/epic-video-BN9tH2d3.js", "/assets/index-Ba7zHVvt.js", "/assets/pe-DXT2FOp1.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/button-DhtjxLl5.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/test": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/test", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": "test", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test-BqhhxMae.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/tests-9K325XZ-.js", "/assets/components-DrvY4pal.js", "/assets/epic-video-BN9tH2d3.js", "/assets/index-Ba7zHVvt.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/accordion-BL_cX9y6.js", "/assets/index-D7-ne3iG.js", "/assets/index-CWadM2q_.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/set-playground-BoPKA2de.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.index": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.index", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_exerciseNumber_._stepNumber.index-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.finished": { "id": "routes/_app+/exercise+/$exerciseNumber_.finished", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber/finished", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_exerciseNumber_.finished-CWHBWFYP.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-BN9tH2d3.js", "/assets/misc-D9k1wGip.js", "/assets/loading-ZSC9wgHC.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/mdx-wFsONSmT.js", "/assets/progress-CpALgZbi.js", "/assets/index-Ba7zHVvt.js", "/assets/online-DZEJ9mQ4.js", "/assets/seo-pBpFCWsy.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/tooltip-CzrLrLJU.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/finished": { "id": "routes/_app+/finished", "parentId": "routes/_app+/_layout", "path": "finished", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/finished-DCXZj8Z6.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-BN9tH2d3.js", "/assets/misc-D9k1wGip.js", "/assets/loading-ZSC9wgHC.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-BIizeOeQ.js", "/assets/mdx-wFsONSmT.js", "/assets/online-DZEJ9mQ4.js", "/assets/seo-pBpFCWsy.js", "/assets/progress-CpALgZbi.js", "/assets/index-Ba7zHVvt.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/tooltip-CzrLrLJU.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/index": { "id": "routes/_app+/index", "parentId": "routes/_app+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/index-I2Jm_PoG.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-BN9tH2d3.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/mdx-wFsONSmT.js", "/assets/misc-D9k1wGip.js", "/assets/progress-CpALgZbi.js", "/assets/components-DrvY4pal.js", "/assets/index-Ba7zHVvt.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/login": { "id": "routes/_app+/login", "parentId": "routes/_app+/_layout", "path": "login", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/login-RlImW-EE.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/button-DhtjxLl5.js", "/assets/loading-ZSC9wgHC.js", "/assets/product-DD8nUALO.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/index-Ba7zHVvt.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js"], "css": [] }, "routes/_app+/preferences": { "id": "routes/_app+/preferences", "parentId": "routes/_app+/_layout", "path": "preferences", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/preferences-DZYeWTq7.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/support": { "id": "routes/_app+/support", "parentId": "routes/_app+/_layout", "path": "support", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/support-CW3-Iilk.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/admin+/_layout": { "id": "routes/admin+/_layout", "parentId": "root", "path": "admin", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-DV29dlKr.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/admin+/apps": { "id": "routes/admin+/apps", "parentId": "routes/admin+/_layout", "path": "apps", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/apps-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/admin+/cache": { "id": "routes/admin+/cache", "parentId": "routes/admin+/_layout", "path": "cache", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/cache-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/admin+/index": { "id": "routes/admin+/index", "parentId": "routes/admin+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-BH_SsYHe.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/progress-CpALgZbi.js", "/assets/components-DrvY4pal.js", "/assets/pe-DXT2FOp1.js"], "css": [] }, "routes/admin+/version": { "id": "routes/admin+/version", "parentId": "routes/admin+/_layout", "path": "version", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/version-D61Qvt0X.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/apps": { "id": "routes/apps", "parentId": "root", "path": "apps", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/apps-DP2rzg_V.js", "imports": [], "css": [] }, "routes/diff": { "id": "routes/diff", "parentId": "root", "path": "diff", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/diff-BIJG7lM0.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/diff-BLwCINNG.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/components-DrvY4pal.js", "/assets/accordion-BL_cX9y6.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-D7-ne3iG.js", "/assets/index-CWadM2q_.js", "/assets/mdx-wFsONSmT.js", "/assets/epic-video-BN9tH2d3.js", "/assets/index-Ba7zHVvt.js", "/assets/pe-DXT2FOp1.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/revalidation-ws-BIizeOeQ.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/exercises": { "id": "routes/exercises", "parentId": "root", "path": "exercises", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/exercises-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/launch-editor": { "id": "routes/launch-editor", "parentId": "root", "path": "launch-editor", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/launch-editor-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/login-sse": { "id": "routes/login-sse", "parentId": "root", "path": "login-sse", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/login-sse-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/og": { "id": "routes/og", "parentId": "root", "path": "og", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/og-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/onboarding": { "id": "routes/onboarding", "parentId": "root", "path": "onboarding", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/onboarding-y1OmFtYT.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/epic-video-BN9tH2d3.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/index-Ba7zHVvt.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-DZEJ9mQ4.js", "/assets/loading-ZSC9wgHC.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/processes": { "id": "routes/processes", "parentId": "root", "path": "processes", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/processes-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/progress": { "id": "routes/progress", "parentId": "root", "path": "progress", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/progress-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/robots[.]txt": { "id": "routes/robots[.]txt", "parentId": "root", "path": "robots.txt", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/robots_._txt-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/set-playground": { "id": "routes/set-playground", "parentId": "root", "path": "set-playground", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/set-playground-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/sitemap[.]xml": { "id": "routes/sitemap[.]xml", "parentId": "root", "path": "sitemap.xml", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/sitemap_._xml-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/start": { "id": "routes/start", "parentId": "root", "path": "start", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/start-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/test": { "id": "routes/test", "parentId": "root", "path": "test", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/theme/index": { "id": "routes/theme/index", "parentId": "root", "path": "theme", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-DP2rzg_V.js", "imports": [], "css": [] }, "routes/video-player/index": { "id": "routes/video-player/index", "parentId": "root", "path": "video-player", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-K6Dvbx-E.js", "imports": [], "css": [] } }, "url": "/assets/manifest-022c9919.js", "version": "022c9919" };
10823
+ const serverManifest = { "entry": { "module": "/assets/entry.client-CQusg5Iz.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes": { "root": { "id": "root", "parentId": void 0, "path": "", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/root-BOerY_70.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/pe-DXT2FOp1.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/progress-bar-IswLOt8e.js", "/assets/index-CB8bjE90.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-BOO5UotZ.js", "/assets/presence-Dmt5LCeW.js", "/assets/seo-pBpFCWsy.js", "/assets/online-BrcRwzQC.js"], "css": [] }, "routes/$": { "id": "routes/$", "parentId": "root", "path": "*", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_-BbjJ9R-5.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/_layout": { "id": "routes/_app+/_layout", "parentId": "root", "path": void 0, "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-DhhhwkhJ.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/pe-DXT2FOp1.js", "/assets/product-CleOH5Nn.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-CWadM2q_.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/online-BrcRwzQC.js", "/assets/presence-Dmt5LCeW.js", "/assets/progress-CpALgZbi.js", "/assets/index-BOO5UotZ.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/account": { "id": "routes/_app+/account", "parentId": "routes/_app+/_layout", "path": "account", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/account-C4MWGVQU.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/app.$appName+/$": { "id": "routes/_app+/app.$appName+/$", "parentId": "routes/_app+/_layout", "path": "app/:appName/*", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/api.$": { "id": "routes/_app+/app.$appName+/api.$", "parentId": "routes/_app+/_layout", "path": "app/:appName/api/*", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/api._-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/epic_ws[.js]": { "id": "routes/_app+/app.$appName+/epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/:appName/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/index": { "id": "routes/_app+/app.$appName+/index", "parentId": "routes/_app+/_layout", "path": "app/:appName/", "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/test.$testName": { "id": "routes/_app+/app.$appName+/test.$testName", "parentId": "routes/_app+/_layout", "path": "app/:appName/test/:testName", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test._testName-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.$appName+/test.epic_ws[.js]": { "id": "routes/_app+/app.$appName+/test.epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/:appName/test/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test.epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/app.epic_ws[.js]": { "id": "routes/_app+/app.epic_ws[.js]", "parentId": "routes/_app+/_layout", "path": "app/epic_ws.js", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/app.epic_ws_.js_-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/discord": { "id": "routes/_app+/discord", "parentId": "routes/_app+/_layout", "path": "discord", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/discord-tUa_uzeh.js", "imports": ["/assets/discord-DsGCI_e6.js", "/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": [] }, "routes/_app+/exercise+/_layout": { "id": "routes/_app+/exercise+/_layout", "parentId": "routes/_app+/_layout", "path": "exercise", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-CwTidn3v.js", "imports": ["/assets/index-CGzylDPY.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber": { "id": "routes/_app+/exercise+/$exerciseNumber", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_exerciseNumber-Bd4c2v-C.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-DoUlMEIW.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/mdx-Ce3knRHx.js", "/assets/progress-CpALgZbi.js", "/assets/misc-D9k1wGip.js", "/assets/seo-pBpFCWsy.js", "/assets/components-DrvY4pal.js", "/assets/index-BOO5UotZ.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber/:stepNumber", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_exerciseNumber_._stepNumber-CZKDy98j.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "path": ":type", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/_layout-cO4Dvl1j.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/mdx-Ce3knRHx.js", "/assets/progress-CpALgZbi.js", "/assets/set-playground-DBPp1Pek.js", "/assets/seo-pBpFCWsy.js", "/assets/misc-D9k1wGip.js", "/assets/epic-video-DoUlMEIW.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-BOO5UotZ.js", "/assets/components-DrvY4pal.js", "/assets/index-CWadM2q_.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/index-D7-ne3iG.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/app": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/app", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": "app", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/app-DK_pEo6e.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/preview-BUkOZv9x.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/index-BOO5UotZ.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/button-DhtjxLl5.js", "/assets/loading-D4V_nJZr.js", "/assets/progress-bar-IswLOt8e.js"], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/index": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/index", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/index-CxEnb-w2.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-D7-ne3iG.js", "/assets/misc-D9k1wGip.js", "/assets/diff-DI-wBaTF.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/loading-D4V_nJZr.js", "/assets/discord-DsGCI_e6.js", "/assets/online-BrcRwzQC.js", "/assets/components-DrvY4pal.js", "/assets/index-CB8bjE90.js", "/assets/set-playground-DBPp1Pek.js", "/assets/tests-B6AwzXv3.js", "/assets/preview-BUkOZv9x.js", "/assets/index-CWadM2q_.js", "/assets/accordion-BL_cX9y6.js", "/assets/mdx-Ce3knRHx.js", "/assets/epic-video-DoUlMEIW.js", "/assets/index-BOO5UotZ.js", "/assets/pe-DXT2FOp1.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/button-DhtjxLl5.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/test": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/test", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.$type+/_layout", "path": "test", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test-DGBB06nI.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/tests-B6AwzXv3.js", "/assets/components-DrvY4pal.js", "/assets/epic-video-DoUlMEIW.js", "/assets/index-BOO5UotZ.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/accordion-BL_cX9y6.js", "/assets/index-D7-ne3iG.js", "/assets/index-CWadM2q_.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/set-playground-DBPp1Pek.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.index": { "id": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber.index", "parentId": "routes/_app+/exercise+/$exerciseNumber_.$stepNumber", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_exerciseNumber_._stepNumber.index-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/_app+/exercise+/$exerciseNumber_.finished": { "id": "routes/_app+/exercise+/$exerciseNumber_.finished", "parentId": "routes/_app+/exercise+/_layout", "path": ":exerciseNumber/finished", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_exerciseNumber_.finished-LvfViAKb.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-DoUlMEIW.js", "/assets/misc-D9k1wGip.js", "/assets/loading-D4V_nJZr.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/mdx-Ce3knRHx.js", "/assets/progress-CpALgZbi.js", "/assets/index-BOO5UotZ.js", "/assets/online-BrcRwzQC.js", "/assets/seo-pBpFCWsy.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/tooltip-CzrLrLJU.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/finished": { "id": "routes/_app+/finished", "parentId": "routes/_app+/_layout", "path": "finished", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/finished-y90Pn48k.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-DoUlMEIW.js", "/assets/misc-D9k1wGip.js", "/assets/loading-D4V_nJZr.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/revalidation-ws-CibzUlFP.js", "/assets/mdx-Ce3knRHx.js", "/assets/online-BrcRwzQC.js", "/assets/seo-pBpFCWsy.js", "/assets/progress-CpALgZbi.js", "/assets/index-BOO5UotZ.js", "/assets/components-DrvY4pal.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/pe-DXT2FOp1.js", "/assets/tooltip-CzrLrLJU.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/index": { "id": "routes/_app+/index", "parentId": "routes/_app+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": true, "module": "/assets/index-De6oiBJI.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/index-egcHQOpF.js", "/assets/epic-video-DoUlMEIW.js", "/assets/error-boundary-DBVB3BBH.js", "/assets/mdx-Ce3knRHx.js", "/assets/misc-D9k1wGip.js", "/assets/progress-CpALgZbi.js", "/assets/components-DrvY4pal.js", "/assets/index-BOO5UotZ.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/_app+/login": { "id": "routes/_app+/login", "parentId": "routes/_app+/_layout", "path": "login", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/login-DiEHnGfv.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/use-event-source-AZJtQsFX.js", "/assets/button-DhtjxLl5.js", "/assets/loading-D4V_nJZr.js", "/assets/product-CleOH5Nn.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/index-BOO5UotZ.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js"], "css": [] }, "routes/_app+/preferences": { "id": "routes/_app+/preferences", "parentId": "routes/_app+/_layout", "path": "preferences", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/preferences-DZYeWTq7.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/_app+/support": { "id": "routes/_app+/support", "parentId": "routes/_app+/_layout", "path": "support", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/support-CW3-Iilk.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/admin+/_layout": { "id": "routes/admin+/_layout", "parentId": "root", "path": "admin", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/_layout-DV29dlKr.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/admin+/apps": { "id": "routes/admin+/apps", "parentId": "routes/admin+/_layout", "path": "apps", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/apps-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/admin+/cache": { "id": "routes/admin+/cache", "parentId": "routes/admin+/_layout", "path": "cache", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/cache-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/admin+/index": { "id": "routes/admin+/index", "parentId": "routes/admin+/_layout", "path": void 0, "index": true, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-BH_SsYHe.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/tooltip-CzrLrLJU.js", "/assets/progress-CpALgZbi.js", "/assets/components-DrvY4pal.js", "/assets/pe-DXT2FOp1.js"], "css": [] }, "routes/admin+/version": { "id": "routes/admin+/version", "parentId": "routes/admin+/_layout", "path": "version", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/version-D61Qvt0X.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/components-DrvY4pal.js"], "css": [] }, "routes/apps": { "id": "routes/apps", "parentId": "root", "path": "apps", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/apps-DP2rzg_V.js", "imports": [], "css": [] }, "routes/diff": { "id": "routes/diff", "parentId": "root", "path": "diff", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/diff-BrUTVi14.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/misc-D9k1wGip.js", "/assets/diff-DI-wBaTF.js", "/assets/nav-chevrons-CM-frhig.js", "/assets/components-DrvY4pal.js", "/assets/accordion-BL_cX9y6.js", "/assets/tooltip-CzrLrLJU.js", "/assets/index-D7-ne3iG.js", "/assets/index-CWadM2q_.js", "/assets/mdx-Ce3knRHx.js", "/assets/epic-video-DoUlMEIW.js", "/assets/index-BOO5UotZ.js", "/assets/pe-DXT2FOp1.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js", "/assets/progress-bar-IswLOt8e.js", "/assets/revalidation-ws-CibzUlFP.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/exercises": { "id": "routes/exercises", "parentId": "root", "path": "exercises", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/exercises-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/launch-editor": { "id": "routes/launch-editor", "parentId": "root", "path": "launch-editor", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/launch-editor-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/login-sse": { "id": "routes/login-sse", "parentId": "root", "path": "login-sse", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/login-sse-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/og": { "id": "routes/og", "parentId": "root", "path": "og", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/og-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/onboarding": { "id": "routes/onboarding", "parentId": "root", "path": "onboarding", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/onboarding-Dnb9KzTs.js", "imports": ["/assets/index-CGzylDPY.js", "/assets/button-DhtjxLl5.js", "/assets/epic-video-DoUlMEIW.js", "/assets/components-DrvY4pal.js", "/assets/misc-D9k1wGip.js", "/assets/index-BOO5UotZ.js", "/assets/tooltip-CzrLrLJU.js", "/assets/pe-DXT2FOp1.js", "/assets/online-BrcRwzQC.js", "/assets/loading-D4V_nJZr.js", "/assets/user-C0j04V55.js", "/assets/workshop-config-oL_FWDKq.js"], "css": ["/assets/epic-video-DUnRvy1A.css"] }, "routes/processes": { "id": "routes/processes", "parentId": "root", "path": "processes", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/processes-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/progress": { "id": "routes/progress", "parentId": "root", "path": "progress", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/progress-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/robots[.]txt": { "id": "routes/robots[.]txt", "parentId": "root", "path": "robots.txt", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/robots_._txt-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/set-playground": { "id": "routes/set-playground", "parentId": "root", "path": "set-playground", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/set-playground-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/sitemap[.]xml": { "id": "routes/sitemap[.]xml", "parentId": "root", "path": "sitemap.xml", "index": void 0, "caseSensitive": void 0, "hasAction": false, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/sitemap_._xml-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/start": { "id": "routes/start", "parentId": "root", "path": "start", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/start-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/test": { "id": "routes/test", "parentId": "root", "path": "test", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": true, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/test-l0sNRNKZ.js", "imports": [], "css": [] }, "routes/theme/index": { "id": "routes/theme/index", "parentId": "root", "path": "theme", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-DP2rzg_V.js", "imports": [], "css": [] }, "routes/video-player/index": { "id": "routes/video-player/index", "parentId": "root", "path": "video-player", "index": void 0, "caseSensitive": void 0, "hasAction": true, "hasLoader": false, "hasClientAction": false, "hasClientLoader": false, "hasErrorBoundary": false, "module": "/assets/index-K6Dvbx-E.js", "imports": [], "css": [] } }, "url": "/assets/manifest-44a29362.js", "version": "44a29362" };
11225
10824
  const mode = "production";
11226
10825
  const assetsBuildDirectory = "build/client";
11227
10826
  const basename = "/";