@slicemachine/init 2.10.17-beta.2 β†’ 2.10.18-beta.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 (105) hide show
  1. package/dist/SliceMachineInitProcess.cjs +3 -5
  2. package/dist/SliceMachineInitProcess.cjs.map +1 -1
  3. package/dist/SliceMachineInitProcess.d.ts +1 -1
  4. package/dist/SliceMachineInitProcess.js +3 -5
  5. package/dist/SliceMachineInitProcess.js.map +1 -1
  6. package/dist/_node_modules/@babel/code-frame/lib/index.cjs +2 -2
  7. package/dist/_node_modules/@babel/code-frame/lib/index.js +2 -2
  8. package/dist/_node_modules/@babel/helper-validator-identifier/lib/index.cjs +1 -1
  9. package/dist/_node_modules/@babel/helper-validator-identifier/lib/index.js +1 -1
  10. package/dist/_node_modules/@babel/highlight/lib/index.cjs +3 -3
  11. package/dist/_node_modules/@babel/highlight/lib/index.js +3 -3
  12. package/dist/_node_modules/@nodelib/fs.scandir/out/providers/async.cjs +1 -1
  13. package/dist/_node_modules/@nodelib/fs.scandir/out/providers/async.js +1 -1
  14. package/dist/_node_modules/@nodelib/fs.scandir/out/providers/sync.cjs +1 -1
  15. package/dist/_node_modules/@nodelib/fs.scandir/out/providers/sync.js +1 -1
  16. package/dist/_node_modules/@nodelib/fs.scandir/out/settings.cjs +1 -1
  17. package/dist/_node_modules/@nodelib/fs.scandir/out/settings.js +1 -1
  18. package/dist/_node_modules/@nodelib/fs.stat/out/index.cjs +1 -1
  19. package/dist/_node_modules/@nodelib/fs.stat/out/index.js +1 -1
  20. package/dist/_node_modules/@nodelib/fs.walk/out/index.cjs +1 -1
  21. package/dist/_node_modules/@nodelib/fs.walk/out/index.js +1 -1
  22. package/dist/_node_modules/cross-spawn/index.cjs +1 -1
  23. package/dist/_node_modules/cross-spawn/index.js +1 -1
  24. package/dist/_node_modules/dir-glob/index.cjs +2 -2
  25. package/dist/_node_modules/dir-glob/index.js +2 -2
  26. package/dist/_node_modules/fast-glob/out/index.cjs +1 -1
  27. package/dist/_node_modules/fast-glob/out/index.js +1 -1
  28. package/dist/_node_modules/fast-glob/out/managers/tasks.cjs +1 -1
  29. package/dist/_node_modules/fast-glob/out/managers/tasks.js +1 -1
  30. package/dist/_node_modules/fast-glob/out/providers/filters/deep.cjs +1 -1
  31. package/dist/_node_modules/fast-glob/out/providers/filters/deep.js +1 -1
  32. package/dist/_node_modules/fast-glob/out/providers/filters/entry.cjs +1 -1
  33. package/dist/_node_modules/fast-glob/out/providers/filters/entry.js +1 -1
  34. package/dist/_node_modules/fast-glob/out/providers/filters/error.cjs +1 -1
  35. package/dist/_node_modules/fast-glob/out/providers/filters/error.js +1 -1
  36. package/dist/_node_modules/fast-glob/out/providers/matchers/matcher.cjs +1 -1
  37. package/dist/_node_modules/fast-glob/out/providers/matchers/matcher.js +1 -1
  38. package/dist/_node_modules/fast-glob/out/providers/transformers/entry.cjs +1 -1
  39. package/dist/_node_modules/fast-glob/out/providers/transformers/entry.js +1 -1
  40. package/dist/_node_modules/fast-glob/out/readers/async.cjs +1 -1
  41. package/dist/_node_modules/fast-glob/out/readers/async.js +1 -1
  42. package/dist/_node_modules/fast-glob/out/readers/reader.cjs +2 -2
  43. package/dist/_node_modules/fast-glob/out/readers/reader.js +2 -2
  44. package/dist/_node_modules/fast-glob/out/readers/stream.cjs +2 -2
  45. package/dist/_node_modules/fast-glob/out/readers/stream.js +2 -2
  46. package/dist/_node_modules/fast-glob/out/readers/sync.cjs +2 -2
  47. package/dist/_node_modules/fast-glob/out/readers/sync.js +2 -2
  48. package/dist/_node_modules/fast-glob/out/utils/index.cjs +1 -1
  49. package/dist/_node_modules/fast-glob/out/utils/index.js +1 -1
  50. package/dist/_node_modules/get-stream/index.cjs +1 -1
  51. package/dist/_node_modules/get-stream/index.js +1 -1
  52. package/dist/_node_modules/js-tokens/index.cjs +1 -1
  53. package/dist/_node_modules/js-tokens/index.js +1 -1
  54. package/dist/_node_modules/lines-and-columns/build/index.cjs +1 -1
  55. package/dist/_node_modules/lines-and-columns/build/index.js +1 -1
  56. package/dist/_node_modules/map-obj/index.cjs +1 -1
  57. package/dist/_node_modules/map-obj/index.js +1 -1
  58. package/dist/_node_modules/meow/_node_modules/hosted-git-info/lib/index.cjs +1 -1
  59. package/dist/_node_modules/meow/_node_modules/hosted-git-info/lib/index.js +1 -1
  60. package/dist/_node_modules/meow/_node_modules/read-pkg/_node_modules/hosted-git-info/index.cjs +1 -1
  61. package/dist/_node_modules/meow/_node_modules/read-pkg/_node_modules/hosted-git-info/index.js +1 -1
  62. package/dist/_node_modules/parse-json/index.cjs +2 -2
  63. package/dist/_node_modules/parse-json/index.js +2 -2
  64. package/dist/_node_modules/path-key/index.cjs +1 -1
  65. package/dist/_node_modules/path-key/index.js +1 -1
  66. package/dist/_node_modules/path-type/index.cjs +1 -1
  67. package/dist/_node_modules/path-type/index.js +1 -1
  68. package/dist/_node_modules/signal-exit/index.cjs +1 -1
  69. package/dist/_node_modules/signal-exit/index.js +1 -1
  70. package/dist/_virtual/index10.cjs +2 -2
  71. package/dist/_virtual/index10.js +2 -2
  72. package/dist/_virtual/index11.cjs +2 -2
  73. package/dist/_virtual/index11.js +2 -2
  74. package/dist/_virtual/index12.cjs +2 -2
  75. package/dist/_virtual/index12.js +2 -2
  76. package/dist/_virtual/index13.cjs +2 -2
  77. package/dist/_virtual/index13.js +2 -2
  78. package/dist/_virtual/index15.cjs +2 -2
  79. package/dist/_virtual/index15.js +2 -2
  80. package/dist/_virtual/index16.cjs +2 -2
  81. package/dist/_virtual/index16.js +2 -2
  82. package/dist/_virtual/index17.cjs +2 -2
  83. package/dist/_virtual/index17.js +2 -2
  84. package/dist/_virtual/index18.cjs +2 -2
  85. package/dist/_virtual/index18.js +2 -2
  86. package/dist/_virtual/index19.cjs +2 -2
  87. package/dist/_virtual/index19.js +2 -2
  88. package/dist/_virtual/index3.cjs +2 -2
  89. package/dist/_virtual/index3.js +2 -2
  90. package/dist/_virtual/index4.cjs +2 -2
  91. package/dist/_virtual/index4.js +2 -2
  92. package/dist/_virtual/index5.cjs +2 -2
  93. package/dist/_virtual/index5.js +2 -2
  94. package/dist/_virtual/index6.cjs +2 -2
  95. package/dist/_virtual/index6.js +2 -2
  96. package/dist/_virtual/index7.cjs +2 -2
  97. package/dist/_virtual/index7.js +2 -2
  98. package/dist/_virtual/index8.cjs +2 -2
  99. package/dist/_virtual/index8.js +2 -2
  100. package/dist/_virtual/index9.cjs +2 -2
  101. package/dist/_virtual/index9.js +2 -2
  102. package/dist/packages/init/package.json.cjs +2 -2
  103. package/dist/packages/init/package.json.js +2 -2
  104. package/package.json +4 -4
  105. package/src/SliceMachineInitProcess.ts +9 -14
@@ -145,6 +145,7 @@ ${chalk.bgGray(` ${chalk.bold.white("Slice Machine")} `)} ${chalk.dim("β†’")} In
145
145
  await this.syncDataWithPrismic();
146
146
  await this.initializeProject();
147
147
  await this.initializePlugins();
148
+ await this.completeOnboardingSteps();
148
149
  } catch (error) {
149
150
  await this.trackError(error);
150
151
  throw error;
@@ -595,11 +596,11 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
595
596
  exists: false
596
597
  };
597
598
  }
598
- async completeOnboardingSteps(...steps) {
599
+ async completeOnboardingSteps() {
599
600
  try {
600
601
  const { value: onboardingExperimentVariant } = await this.manager.telemetry.getExperimentVariant("shared-onboarding") ?? {};
601
602
  if (onboardingExperimentVariant === "with-shared-onboarding") {
602
- this.manager.prismicRepository.completeOnboardingStep(...steps);
603
+ this.manager.prismicRepository.completeOnboardingStep("chooseLocale", "createProject", "setupSliceMachine");
603
604
  }
604
605
  } catch (error) {
605
606
  await this.trackError(error);
@@ -619,7 +620,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
619
620
  framework: this.context.framework.wroomTelemetryID,
620
621
  starterId: this.context.starterId
621
622
  });
622
- await this.completeOnboardingSteps("createProject", "setupSliceMachine");
623
623
  } catch (error) {
624
624
  await this.manager.user.logout();
625
625
  task.output = "It seems there is an authentication problem, press any key to open the browser to login again...";
@@ -642,7 +642,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
642
642
  async setDefaultMasterLocale() {
643
643
  const documentsRead = await this.readDocuments();
644
644
  if (documentsRead !== void 0 && documentsRead.documents.length > 0) {
645
- await this.completeOnboardingSteps("chooseLocale");
646
645
  return;
647
646
  }
648
647
  return listr.listrRun([
@@ -651,7 +650,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
651
650
  task: async (_, task) => {
652
651
  await this.manager.prismicRepository.setDefaultMasterLocale();
653
652
  task.title = `Main content language set to ${chalk.cyan("English - United States")} πŸ‡ΊπŸ‡Έ. You can change it anytime in your project settings.`;
654
- await this.completeOnboardingSteps("chooseLocale");
655
653
  }
656
654
  }
657
655
  ]);
@@ -1 +1 @@
1
- {"version":3,"file":"SliceMachineInitProcess.cjs","sources":["../../src/SliceMachineInitProcess.ts"],"sourcesContent":["import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\n\nimport chalk from \"chalk\";\n\nimport { execaCommand, type ExecaChildProcess } from \"execa\";\n\nimport open from \"open\";\nimport logSymbols from \"log-symbols\";\nimport { globby } from \"globby\";\nimport { downloadTemplate } from \"giget\";\nimport pLimit from \"p-limit\";\n\nimport {\n\tcreateSliceMachineManager,\n\tPrismicUserProfile,\n\tPrismicRepository,\n\tSliceMachineManager,\n\tPackageManager,\n\tStarterId,\n\tREPOSITORY_NAME_VALIDATION,\n} from \"@slicemachine/manager\";\n\nimport pkg from \"../package.json\";\nimport { detectFramework, Framework } from \"./lib/framework\";\nimport { getRunScriptCommand } from \"./lib/getRunScriptCommand\";\nimport { getExecuteCommand } from \"./lib/getExecuteCommand\";\nimport {\n\tgetRandomRepositoryDomain,\n\tformatRepositoryDomain,\n\tvalidateRepositoryDomain,\n\tvalidateRepositoryDomainAndAvailability,\n\tgetErrorMessageForRepositoryDomainValidation,\n} from \"./lib/repositoryDomain\";\nimport { listr, listrRun } from \"./lib/listr\";\nimport { prompt } from \"./lib/prompt\";\nimport { assertExists } from \"./lib/assertExists\";\nimport {\n\tGIGET_ORGANIZATION,\n\tGIGET_PROVIDER,\n\tSLICE_MACHINE_INIT_USER_AGENT,\n\tSTART_SCRIPT_KEY,\n\tSTART_SCRIPT_VALUE,\n} from \"./constants\";\nimport { detectStarterId } from \"./lib/starters\";\nimport { setupSentry } from \"./lib/setupSentry\";\nimport { trackSentryError } from \"./lib/sentryErrorHandlers\";\nimport { updateSentryContext } from \"./lib/updateSentryContext\";\n\nexport type SliceMachineInitProcessOptions = {\n\trepository?: string;\n\tstarter?: string;\n\tdirectoryName?: string;\n\tpush?: boolean;\n\tpushSlices?: boolean;\n\tpushCustomTypes?: boolean;\n\tpushDocuments?: boolean;\n\tstartSlicemachine?: boolean;\n\tcwd?: string;\n} & Record<string, unknown>;\n\nconst DEFAULT_OPTIONS: SliceMachineInitProcessOptions = {\n\tpush: true,\n\tpushSlices: true,\n\tpushCustomTypes: true,\n\tpushDocuments: true,\n\tstartSlicemachine: true,\n};\n\nexport const createSliceMachineInitProcess = (\n\toptions?: SliceMachineInitProcessOptions,\n): SliceMachineInitProcess => {\n\treturn new SliceMachineInitProcess(options);\n};\n\ntype SliceMachineInitProcessContext = {\n\tframework?: Framework;\n\tpackageManager?: PackageManager;\n\tinstallProcess?: ExecaChildProcess;\n\tuserProfile?: PrismicUserProfile;\n\tuserRepositories?: PrismicRepository[];\n\trepository?: {\n\t\tdomain: string;\n\t\texists: boolean;\n\t};\n\tprojectInitialization?: {\n\t\tpatchedScript?: boolean;\n\t};\n\tstarterId?: StarterId;\n};\n\nexport class SliceMachineInitProcess {\n\tprotected options: SliceMachineInitProcessOptions;\n\tprotected manager: SliceMachineManager;\n\n\tprotected context: SliceMachineInitProcessContext;\n\n\tconstructor(options?: SliceMachineInitProcessOptions) {\n\t\tthis.options = { ...DEFAULT_OPTIONS, ...options };\n\t\tthis.manager = createSliceMachineManager({ cwd: options?.cwd });\n\n\t\tthis.context = {};\n\t}\n\n\tasync run(): Promise<void> {\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGray(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"β†’\",\n\t\t\t)} Initializing\\n`,\n\t\t);\n\n\t\ttry {\n\t\t\ttry {\n\t\t\t\tawait setupSentry();\n\t\t\t} catch (error) {\n\t\t\t\t// noop - We don't want to stop the user from using Slice Machine\n\t\t\t\t// because of failed tracking set up. We probably couldn't determine the\n\t\t\t\t// Sentry environment.\n\t\t\t}\n\t\t\tif (this.options.starter) {\n\t\t\t\tawait this.copyStarter();\n\t\t\t} else if (this.options.directoryName) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${logSymbols.warning} --directory-name has no effect because --starter is not specified\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (await this.manager.telemetry.checkIsTelemetryEnabled()) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${\n\t\t\t\t\t\tlogSymbols.info\n\t\t\t\t\t} We collect telemetry data to improve user experience.\\n Learn more: ${chalk.cyan(\n\t\t\t\t\t\t\"https://prismic.dev/slice-machine/telemetry\",\n\t\t\t\t\t)}\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tawait this.manager.telemetry.initTelemetry({\n\t\t\t\tappName: pkg.name,\n\t\t\t\tappVersion: pkg.version,\n\t\t\t});\n\n\t\t\tawait this.manager.telemetry.track({\n\t\t\t\tevent: \"command:init:start\",\n\t\t\t\trepository: this.options.repository,\n\t\t\t});\n\n\t\t\tawait this.detectEnvironment();\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.framework,\n\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.beginCoreDependenciesInstallation();\n\n\t\t\tif (this.options.repository) {\n\t\t\t\tawait this.useRepositoryFlag();\n\t\t\t} else {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tawait this.selectRepository();\n\t\t\t}\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.repository,\n\t\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.finishCoreDependenciesInstallation();\n\t\t\tawait this.upsertSliceMachineConfigurationAndStartPluginRunner();\n\n\t\t\tconst isLoginRequired = await this.checkIsLoginRequired();\n\t\t\tif (isLoginRequired) {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tif (this.context.repository.exists) {\n\t\t\t\t\tthis.validateWriteAccess();\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!this.context.repository.exists) {\n\t\t\t\tawait this.createNewRepository();\n\t\t\t\tawait this.setDefaultMasterLocale();\n\t\t\t}\n\n\t\t\tawait this.syncDataWithPrismic();\n\t\t\tawait this.initializeProject();\n\t\t\tawait this.initializePlugins();\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\n\t\t\tthrow error;\n\t\t}\n\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework.sliceMachineTelemetryID,\n\t\t\trepository: this.context.repository.domain,\n\t\t\tsuccess: true,\n\t\t});\n\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGreen(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"β†’\",\n\t\t\t)} Initialization successful!\n\nContinue with next steps in Slice Machine.\n`,\n\t\t);\n\n\t\ttry {\n\t\t\tif (this.options.startSlicemachine) {\n\t\t\t\tconst runSmCommand = this.context.projectInitialization?.patchedScript\n\t\t\t\t\t? await getRunScriptCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"slicemachine\",\n\t\t\t\t\t })\n\t\t\t\t\t: await getExecuteCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"start-slicemachine\",\n\t\t\t\t\t });\n\n\t\t\t\tconst { startSlicemachine } = await prompt<\n\t\t\t\t\tboolean,\n\t\t\t\t\t\"startSlicemachine\"\n\t\t\t\t>({\n\t\t\t\t\ttype: \"confirm\",\n\t\t\t\t\tname: \"startSlicemachine\",\n\t\t\t\t\tmessage: `Run Slice Machine (${chalk.cyan(runSmCommand)})?`,\n\t\t\t\t\tinitial: true,\n\t\t\t\t});\n\n\t\t\t\tif (startSlicemachine) {\n\t\t\t\t\tconst commandReturnValue = await execaCommand(runSmCommand, {\n\t\t\t\t\t\tenv: { FORCE_COLOR: \"true\" },\n\t\t\t\t\t}).pipeStdout?.(process.stdout);\n\t\t\t\t\tif (commandReturnValue !== undefined) {\n\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\tconsole.log(commandReturnValue.stdout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\t// Only track this error with Sentry, it's only the final convenience message\n\t\t\tawait this.trackSentryError(error);\n\t\t}\n\t}\n\n\tprotected async checkIsLoginRequired(): Promise<boolean> {\n\t\ttry {\n\t\t\tassertExists(this.context.repository, \"\");\n\t\t\tif (this.context.repository.exists === false) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tconst [slices, ctLibrary, documentsGlob] = await Promise.all([\n\t\t\t\tthis.readAllSlices(),\n\t\t\t\tthis.manager.customTypes.readCustomTypeLibrary(),\n\t\t\t\tthis.readDocuments(),\n\t\t\t]);\n\n\t\t\t// If repository exists, and there's anything to push\n\t\t\tif (\n\t\t\t\tslices.length > 0 ||\n\t\t\t\tctLibrary.ids.length > 0 ||\n\t\t\t\t(documentsGlob !== undefined && documentsGlob.documents.length > 0)\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// If repository exists, and there might be things to pull\n\t\t\tif (ctLibrary.ids.length === 0) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tprotected trackError = async (error: unknown): Promise<void> => {\n\t\tawait this.trackSentryError(error);\n\t\tawait this.trackTelemetryError(error);\n\t};\n\n\tprotected trackTelemetryError = async (error: unknown): Promise<void> => {\n\t\t// Transform error to string and prevent hitting Segment 500kb API limit or sending ridiculously long trace\n\t\tconst safeError = (\n\t\t\terror instanceof Error ? error.message : `${error}`\n\t\t).slice(0, 512);\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t\trepository: this.context.repository?.domain || \"\",\n\t\t\tsuccess: false,\n\t\t\terror: safeError,\n\t\t});\n\t};\n\n\tprotected trackSentryError = async (error: unknown): Promise<void> => {\n\t\tawait updateSentryContext({\n\t\t\tmanager: this.manager,\n\t\t\trepositoryName: this.context.repository?.domain || \"\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t});\n\t\ttrackSentryError(error);\n\t};\n\n\tprotected async copyStarter(): Promise<void> {\n\t\tconst dir = await this.getStarterDirectoryName();\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Copying starter...\\n\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tconst starter = this.options.starter;\n\n\t\t\t\t\tawait downloadTemplate(\n\t\t\t\t\t\t`${GIGET_PROVIDER}:${GIGET_ORGANIZATION}/${starter}#HEAD`,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tdir,\n\t\t\t\t\t\t},\n\t\t\t\t\t);\n\n\t\t\t\t\tprocess.chdir(dir);\n\t\t\t\t\tthis.manager.cwd = process.cwd();\n\n\t\t\t\t\ttask.title = \"Starter copied\\n\";\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async getStarterDirectoryName(): Promise<string> {\n\t\tlet directoryName: string;\n\t\tconst folderNames = await fs.readdir(process.cwd());\n\n\t\tif (\n\t\t\tthis.options.directoryName &&\n\t\t\t!folderNames.includes(this.options.directoryName)\n\t\t) {\n\t\t\t// Use provided directory\n\t\t\tdirectoryName = this.options.directoryName;\n\t\t} else if (\n\t\t\tthis.options.repository &&\n\t\t\t!folderNames.includes(this.options.repository)\n\t\t) {\n\t\t\t// Use repository name\n\t\t\tdirectoryName = this.options.repository;\n\t\t} else {\n\t\t\t// Use random name\n\t\t\tlet suggestedName: string;\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (folderNames.includes(suggestedName));\n\n\t\t\tconst { selectedDirectory } = await prompt<string, \"selectedDirectory\">({\n\t\t\t\ttype: \"text\",\n\t\t\t\tname: \"selectedDirectory\",\n\t\t\t\tmessage: \"Your starter directory name\",\n\t\t\t\tinitial: suggestedName,\n\t\t\t\tvalidate: async (rawDirectory: string) => {\n\t\t\t\t\tif (folderNames.includes(rawDirectory)) {\n\t\t\t\t\t\treturn \"Directory name already exists\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tdirectoryName = selectedDirectory;\n\t\t}\n\n\t\treturn directoryName;\n\t}\n\n\tprotected detectEnvironment(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Detecting environment...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting framework...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.framework = await detectFramework(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting package manager...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.packageManager =\n\t\t\t\t\t\t\t\t\tawait this.manager.project.detectPackageManager({\n\t\t\t\t\t\t\t\t\t\troot: this.manager.cwd,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\ttask.title = `Detected package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tparentTask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)} and package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting starter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.starterId = await detectStarterId(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\tif (this.context.starterId) {\n\t\t\t\t\t\t\t\t\ttask.title = `Detected starter ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.starterId,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\ttask.title = \"No starter detected\";\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected beginCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Beginning core dependencies installation...\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\"Project package manager must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst { execaProcess } =\n\t\t\t\t\t\tawait this.manager.project.installDependencies({\n\t\t\t\t\t\t\tpackageManager: this.context.packageManager,\n\t\t\t\t\t\t\tdependencies: this.context.framework.devDependencies,\n\t\t\t\t\t\t\tdev: true,\n\t\t\t\t\t\t\t// Picked up later\n\t\t\t\t\t\t\tlog: () => {\n\t\t\t\t\t\t\t\t/* ... */\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\n\t\t\t\t\t// Fail hard if process fails\n\t\t\t\t\texecaProcess.catch(async (error) => {\n\t\t\t\t\t\tconst [_, ...argv1n] = process.argv;\n\t\t\t\t\t\t// Command the user used\n\t\t\t\t\t\tlet tryAgainCommand = [process.argv0, ...argv1n].join(\" \");\n\n\t\t\t\t\t\t// If the `repository` option wasn't used AND the repository was selected/created\n\t\t\t\t\t\tif (!this.options.repository && this.context.repository) {\n\t\t\t\t\t\t\ttryAgainCommand = `${tryAgainCommand} --repository=${this.context.repository.domain}`;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tawait this.trackError(error);\n\t\t\t\t\t\tconsole.error(\n\t\t\t\t\t\t\t`\\n\\n${error.shortMessage}\\n${error.stderr}\\n\\n${\n\t\t\t\t\t\t\t\tlogSymbols.error\n\t\t\t\t\t\t\t} Dependency installation failed, try again with:\\n\\n ${chalk.gray(\n\t\t\t\t\t\t\t\t\"$\",\n\t\t\t\t\t\t\t)} ${chalk.cyan(tryAgainCommand)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tprocess.exit(1);\n\t\t\t\t\t});\n\n\t\t\t\t\tthis.context.installProcess = execaProcess;\n\n\t\t\t\t\ttask.title = `Began core dependencies installation with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)} ... (running in background)`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async fetchUserProfile(): Promise<void> {\n\t\tthis.context.userProfile = await this.manager.user.getProfile();\n\n\t\tawait this.manager.telemetry.identify({\n\t\t\tuserID: this.context.userProfile.shortId,\n\t\t\tintercomHash: this.context.userProfile.intercomHash,\n\t\t});\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:identify\",\n\t\t\trepository: this.options.repository,\n\t\t});\n\t}\n\n\tprotected async fetchUserRepositories(): Promise<void> {\n\t\tthis.context.userRepositories =\n\t\t\tawait this.manager.prismicRepository.readAll();\n\t}\n\n\tprotected validateWriteAccess(): void {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to validate write access\",\n\t\t);\n\t\tconst { domain } = this.context.repository;\n\t\tconst maybeRepository = this.context.userRepositories.find(\n\t\t\t(repository) => repository.domain === domain,\n\t\t);\n\n\t\tif (maybeRepository) {\n\t\t\tif (!this.manager.prismicRepository.hasWriteAccess(maybeRepository)) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Cannot run init command with repository ${chalk.cyan(\n\t\t\t\t\t\tmaybeRepository.domain,\n\t\t\t\t\t)}: you are not a developer or admin of this repository`,\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot validate write access for repository ${chalk.cyan(\n\t\t\t\t\tdomain,\n\t\t\t\t)}: you are not part of this repository`,\n\t\t\t);\n\t\t}\n\t}\n\n\tprotected getLoggingInTitle(subtitle?: string, ...extra: string[]): string {\n\t\treturn `Logging in to Prismic...\n\t\t\nβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ\n\n${subtitle ? `* * ${subtitle}` : \"\"}\n${extra.length ? `\\n${extra.map((line) => ` ${line}`).join(\"\\n\")}\\n` : \"\"}\nβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ\n`;\n\t}\n\n\tprotected loginAndFetchUserData(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: this.getLoggingInTitle(),\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\"Validating session...\");\n\t\t\t\t\tconst isLoggedIn = await this.manager.user.checkIsLoggedIn();\n\n\t\t\t\t\tif (!isLoggedIn) {\n\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\tchalk.cyan(\"Press any key to open the browser to login...\"),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\tawait this.waitingForLogin(({ url }) => {\n\t\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\t\tchalk.cyan(\"Opening browser, waiting for you to login...\"),\n\t\t\t\t\t\t\t\tchalk.yellow(\n\t\t\t\t\t\t\t\t\t\"If your browser did not open automatically, please use the url below:\",\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tparentTask.title = `Logged in`;\n\n\t\t\t\t\treturn listr(\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user profile...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserProfile();\n\t\t\t\t\t\t\t\t\tparentTask.title = `Logged in as ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.userProfile?.email,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user profile\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user repositories...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserRepositories();\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user repositories\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t],\n\t\t\t\t\t\t{ concurrent: true },\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async pressKeyToLogin(): Promise<void> {\n\t\tawait new Promise((resolve) => {\n\t\t\tconst initialRawMode = !!process.stdin.isRaw;\n\t\t\tprocess.stdin.setRawMode?.(true);\n\t\t\tprocess.stdin.resume();\n\t\t\tprocess.stdin.once(\"data\", (data: Buffer) => {\n\t\t\t\tprocess.stdin.setRawMode?.(initialRawMode);\n\t\t\t\tprocess.stdin.pause();\n\t\t\t\tresolve(data.toString(\"utf-8\"));\n\t\t\t});\n\t\t});\n\t}\n\n\tprotected async waitingForLogin(\n\t\tonListenCallback?: (\n\t\t\tsessionInfo: Awaited<\n\t\t\t\tReturnType<typeof this.manager.user.getLoginSessionInfo>\n\t\t\t>,\n\t\t) => void,\n\t): Promise<void> {\n\t\tconst sessionInfo = await this.manager.user.getLoginSessionInfo();\n\t\tawait this.manager.user.nodeLoginSession({\n\t\t\tport: sessionInfo.port,\n\t\t\tonListenCallback() {\n\t\t\t\topen(sessionInfo.url);\n\t\t\t\tonListenCallback?.(sessionInfo);\n\t\t\t},\n\t\t});\n\t}\n\n\tprotected useRepositoryFlag(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Flag ${chalk.cyan(\"repository\")} used, validating input...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.options.repository,\n\t\t\t\t\t\t\"Flag `repository` must be set to run `useRepositoryFlag`\",\n\t\t\t\t\t);\n\t\t\t\t\tconst domain = formatRepositoryDomain(this.options.repository);\n\t\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t\t});\n\n\t\t\t\t\tif (validation.LessThanMin || validation.MoreThanMax) {\n\t\t\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\t\t\tvalidation: {\n\t\t\t\t\t\t\t\t...validation,\n\t\t\t\t\t\t\t\t// We don't want to throw if repo already exists.\n\t\t\t\t\t\t\t\t// User most probably just created it via their dashboard.\n\t\t\t\t\t\t\t\tAlreadyExists: false,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (errorMessage) {\n\t\t\t\t\t\t\tthrow new Error(errorMessage);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Selected repository ${chalk.cyan(\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t)} (flag ${chalk.cyan(\"repository\")} used)`;\n\n\t\t\t\t\tthis.context.repository = {\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texists: validation.AlreadyExists ?? false,\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async selectRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `selectRepository`\",\n\t\t);\n\n\t\tif (this.context.userRepositories.length) {\n\t\t\tawait this.trySelectExistingRepository();\n\t\t}\n\n\t\tif (!this.context.repository) {\n\t\t\tawait this.selectNewRepository();\n\t\t}\n\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`${logSymbols.success} Selected repository ${chalk.cyan(\n\t\t\t\tthis.context.repository.domain,\n\t\t\t)}`,\n\t\t);\n\t}\n\n\tprotected async trySelectExistingRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `trySelectExistingRepository`\",\n\t\t);\n\n\t\tconst { maybeDomain } = await prompt<string, \"maybeDomain\">({\n\t\t\ttype: \"select\",\n\t\t\tname: \"maybeDomain\",\n\t\t\tmessage: \"Pick a repository to connect to or choose to create a new one\",\n\t\t\twarn: \"You are not a developer or admin of this repository\",\n\t\t\tchoices: [\n\t\t\t\t{\n\t\t\t\t\ttitle: \"CREATE NEW\",\n\t\t\t\t\tdescription: \"Create a new Prismic repository\\n\",\n\t\t\t\t\tvalue: \"\",\n\t\t\t\t},\n\t\t\t\t...this.context.userRepositories\n\t\t\t\t\t.map((repository) => {\n\t\t\t\t\t\tconst hasWriteAccess =\n\t\t\t\t\t\t\tthis.manager.prismicRepository.hasWriteAccess(repository);\n\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\ttitle: `${repository.domain}${\n\t\t\t\t\t\t\t\thasWriteAccess ? \"\" : \" (Unauthorized)\"\n\t\t\t\t\t\t\t}`,\n\t\t\t\t\t\t\tdescription: `Connect to ${chalk.cyan(repository.domain)}`,\n\t\t\t\t\t\t\tvalue: repository.domain,\n\t\t\t\t\t\t\tdisabled: !hasWriteAccess,\n\t\t\t\t\t\t};\n\t\t\t\t\t})\n\t\t\t\t\t.sort((a, b) => (a.value > b.value ? 1 : -1)),\n\t\t\t],\n\t\t});\n\n\t\tif (maybeDomain) {\n\t\t\tthis.context.repository = {\n\t\t\t\tdomain: maybeDomain,\n\t\t\t\texists: true,\n\t\t\t};\n\t\t}\n\t}\n\n\tprotected async selectNewRepository(): Promise<void> {\n\t\tlet suggestedName = \"\";\n\n\t\t// TODO: Improve concurrency\n\t\tconst trySuggestName = async (name: string): Promise<string | void> => {\n\t\t\tif (name) {\n\t\t\t\tconst formattedName = formatRepositoryDomain(name);\n\n\t\t\t\tif (\n\t\t\t\t\t!validateRepositoryDomain({ domain: formattedName }).hasErrors &&\n\t\t\t\t\t!(await this.manager.prismicRepository.checkExists({\n\t\t\t\t\t\tdomain: formattedName,\n\t\t\t\t\t}))\n\t\t\t\t) {\n\t\t\t\t\treturn formattedName;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// 1. Try to suggest name after directory name\n\t\tconst maybeSuggestion = await trySuggestName(\n\t\t\tpath.basename(this.manager.cwd),\n\t\t);\n\t\tif (maybeSuggestion) {\n\t\t\tsuggestedName = maybeSuggestion;\n\t\t}\n\n\t\t// 2. Try to suggest name after package name\n\t\tif (!suggestedName) {\n\t\t\ttry {\n\t\t\t\tconst pkgJSONPath = path.join(this.manager.cwd, \"package.json\");\n\t\t\t\tconst pkg = JSON.parse(await fs.readFile(pkgJSONPath, \"utf-8\"));\n\n\t\t\t\tconst maybeSuggestion = await trySuggestName(pkg.name);\n\t\t\t\tif (maybeSuggestion) {\n\t\t\t\t\tsuggestedName = maybeSuggestion;\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Noop\n\t\t\t}\n\t\t}\n\n\t\t// 3. Use random name\n\t\tif (!suggestedName) {\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (\n\t\t\t\tawait this.manager.prismicRepository.checkExists({\n\t\t\t\t\tdomain: suggestedName,\n\t\t\t\t})\n\t\t\t);\n\t\t}\n\n\t\tconst { domain } = await prompt<string, \"domain\">({\n\t\t\ttype: \"text\",\n\t\t\tname: \"domain\",\n\t\t\t// Overriden by the `onRender` function, just used as a fallback\n\t\t\tmessage: \"Choose a name for your Prismic repository\",\n\t\t\tinitial: suggestedName,\n\t\t\tonRender() {\n\t\t\t\tconst rawDomain = this.value || this.initial || \"\";\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = validateRepositoryDomain({ domain });\n\n\t\t\t\tconst minRule = validation.LessThanMin\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tconst maxRule = validation.MoreThanMax\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tthis.msg = chalk.reset(\n\t\t\t\t\t`\nChoose a name for your Prismic repository\n\n NAMING RULES\n ${minRule}\n ${maxRule}\n 3. Name will be ${chalk.cyan(\"kebab-cased\")} automatically\n\n CONSIDERATIONS\n 1. Once picked, your repository name ${chalk.cyan(\"cannot be changed\")}\n 2. A ${chalk.cyan(\n\t\t\t\"display name\",\n\t\t)} for the repository can be configured later on\n\n PREVIEW\n Dashboard ${chalk.cyan(`https://${domain}.prismic.io`)}\n API ${chalk.cyan(`https://${domain}.cdn.prismic.io/api/v2`)}\n\n${chalk.cyan(\"?\")} Your Prismic repository name`.replace(\"\\n\", \"\"),\n\t\t\t\t);\n\t\t\t},\n\t\t\tvalidate: async (rawDomain: string) => {\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\tdomain,\n\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t});\n\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\tvalidation,\n\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t});\n\n\t\t\t\treturn errorMessage || true;\n\t\t\t},\n\t\t\tformat: (value) => {\n\t\t\t\treturn formatRepositoryDomain(value);\n\t\t\t},\n\t\t});\n\n\t\t// Clear extra lines\n\t\tprocess.stdout.moveCursor?.(0, -16);\n\t\tprocess.stdout.clearScreenDown?.();\n\n\t\tthis.context.repository = {\n\t\t\tdomain,\n\t\t\texists: false,\n\t\t};\n\t}\n\n\tprotected async completeOnboardingSteps(...steps: string[]): Promise<void> {\n\t\ttry {\n\t\t\tconst { value: onboardingExperimentVariant } =\n\t\t\t\t(await this.manager.telemetry.getExperimentVariant(\n\t\t\t\t\t\"shared-onboarding\",\n\t\t\t\t)) ?? {};\n\t\t\tif (onboardingExperimentVariant === \"with-shared-onboarding\") {\n\t\t\t\tthis.manager.prismicRepository.completeOnboardingStep(...steps);\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\t\t}\n\t}\n\tprotected createNewRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t);\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Creating new repository ${chalk.cyan(\n\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tawait this.completeOnboardingSteps(\n\t\t\t\t\t\t\t\"createProject\",\n\t\t\t\t\t\t\t\"setupSliceMachine\",\n\t\t\t\t\t\t);\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t// When we have an error here, it's most probably because the user has a stale SESSION cookie\n\n\t\t\t\t\t\t// Ensure to logout user to remove SESSION and prismic-auth cookies\n\t\t\t\t\t\tawait this.manager.user.logout();\n\n\t\t\t\t\t\t// Force a new login to get a brand new cookies value\n\t\t\t\t\t\ttask.output =\n\t\t\t\t\t\t\t\"It seems there is an authentication problem, press any key to open the browser to login again...\";\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\ttask.output = \"Browser opened, waiting for you to login...\";\n\t\t\t\t\t\tawait this.waitingForLogin();\n\n\t\t\t\t\t\t// Try to create repository again with the new cookies value\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context.repository.exists = true;\n\t\t\t\t\ttask.output = \"\";\n\t\t\t\t\ttask.title = `Created new repository ${chalk.cyan(\n\t\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async setDefaultMasterLocale(): Promise<void> {\n\t\tconst documentsRead = await this.readDocuments();\n\n\t\tif (documentsRead !== undefined && documentsRead.documents.length > 0) {\n\t\t\t// if there are documents to push, we assume it's a starter which\n\t\t\t// has a master locale already set, and we only ensure the onboarding\n\t\t\t// step is completed.\n\t\t\tawait this.completeOnboardingSteps(\"chooseLocale\");\n\n\t\t\treturn;\n\t\t}\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Setting main content language...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tawait this.manager.prismicRepository.setDefaultMasterLocale();\n\t\t\t\t\ttask.title = `Main content language set to ${chalk.cyan(\n\t\t\t\t\t\t\"English - United States\",\n\t\t\t\t\t)} πŸ‡ΊπŸ‡Έ. You can change it anytime in your project settings.`;\n\n\t\t\t\t\tawait this.completeOnboardingSteps(\"chooseLocale\");\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected finishCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Finishing core dependencies installation with ${chalk.cyan(\n\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.installProcess,\n\t\t\t\t\t\t\"Initial dependencies installation process must be available through context to run `finishCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst updateOutput = (data: Buffer | null) => {\n\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\n\t\t\t\t\t// Don't clutter console with logs when process is non TTY (CI, etc.)\n\t\t\t\t\tif (process.stdout.isTTY || process.env.NODE_ENV === \"test\") {\n\t\t\t\t\t\tthis.context.installProcess.stdout?.on(\"data\", updateOutput);\n\t\t\t\t\t}\n\t\t\t\t\tthis.context.installProcess.stderr?.on(\"data\", updateOutput);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.context.installProcess;\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Error catching happens when then process is started ealier so\n\t\t\t\t\t\t * that all install errors, earlier and presents, can be catched.\n\t\t\t\t\t\t *\n\t\t\t\t\t\t * Here, we force the task to wait so that it is neither marked as\n\t\t\t\t\t\t * done or has the opportunity to handle the error itself.\n\t\t\t\t\t\t */\n\t\t\t\t\t\t// If for whatever reason the process is not exited by now, we still throw the error\n\t\t\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 5000));\n\t\t\t\t\t\tthrow error;\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Installed core dependencies with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected upsertSliceMachineConfigurationAndStartPluginRunner(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Resolving Slice Machine configuration...\",\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tlet sliceMachineConfigExists = false;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.project.getSliceMachineConfigPath();\n\t\t\t\t\t\tsliceMachineConfigExists = true;\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// noop, config does not exists, we'll create it\n\t\t\t\t\t}\n\n\t\t\t\t\tif (sliceMachineConfigExists) {\n\t\t\t\t\t\tparentTask.title = \"Updating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst config = await this.manager.project.getSliceMachineConfig();\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t\tparentTask.title = \"Updated Slice Machine configuration\";\n\t\t\t\t\t} else {\n\t\t\t\t\t\tparentTask.title = \"Creating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst sliceMachineConfigPath =\n\t\t\t\t\t\t\tawait this.manager.project.suggestSliceMachineConfigPath();\n\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t\tlibraries: [\"./slices\"],\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tpath: sliceMachineConfigPath,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tparentTask.title = \"Created Slice Machine configuration\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn listr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t// title: \"Starting plugin runner...\",\n\t\t\t\t\t\t\ttitle: \"Loading adapter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tawait this.manager.plugins.initPlugins();\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// task.title = \"Started plugin runner\";\n\t\t\t\t\t\t\t\ttask.title = \"Loaded adapter\";\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// parentTask.title = `${parentTask.title} and started plugin runner`;\n\t\t\t\t\t\t\t\tparentTask.title = `${parentTask.title} and loaded adapter`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async readAllSlices(): Promise<\n\t\t{ libraryID: string; sliceID: string }[]\n\t> {\n\t\tconst { libraries, errors } =\n\t\t\tawait this.manager.slices.readAllSliceLibraries();\n\n\t\tif (errors.length > 0) {\n\t\t\t// TODO: Provide better error message.\n\t\t\tthrow new Error(`Failed to read slice libraries: ${errors.join(\", \")}`);\n\t\t}\n\n\t\tconst slices: { libraryID: string; sliceID: string }[] = [];\n\t\tfor (const library of libraries) {\n\t\t\tif (library.sliceIDs) {\n\t\t\t\tfor (const sliceID of library.sliceIDs) {\n\t\t\t\t\tslices.push({\n\t\t\t\t\t\tlibraryID: library.libraryID,\n\t\t\t\t\t\tsliceID,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn slices;\n\t}\n\n\tprotected async readDocuments(): Promise<\n\t\t| {\n\t\t\t\tsignature: string;\n\t\t\t\tdocuments: string[];\n\t\t\t\tdirectoryPath: string;\n\t\t }\n\t\t| undefined\n\t> {\n\t\tconst root = await this.manager.project.getRoot();\n\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\ttry {\n\t\t\tawait fs.access(documentsDirectoryPath);\n\t\t} catch {\n\t\t\treturn;\n\t\t}\n\t\tconst signaturePath = path.resolve(documentsDirectoryPath, \"index.json\");\n\t\tconst rawSignature = await fs.readFile(signaturePath, \"utf-8\");\n\t\tconst signature: string = JSON.parse(rawSignature).signature;\n\n\t\tconst documents = await globby(\"*/*.json\", {\n\t\t\tcwd: documentsDirectoryPath,\n\t\t});\n\n\t\treturn { signature, documents, directoryPath: documentsDirectoryPath };\n\t}\n\n\tprotected syncDataWithPrismic(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Syncing data with Prismic...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing slices...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushSlices) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-slices used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst slices = await this.readAllSlices();\n\n\t\t\t\t\t\t\t\tif (slices.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No slice to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushing slices... (initializing ACL)\";\n\t\t\t\t\t\t\t\tawait this.manager.screenshots.initS3ACL();\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (0/${slices.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tslices.map(async (slice) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.slices.pushSlice({\n\t\t\t\t\t\t\t\t\t\t\t...slice,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (${pushed}/${slices.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all slices\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing types...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushCustomTypes) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-custom-types used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (!ids || ids.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No custom type to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing types... (0/${ids.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tids.map(async (id) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.pushCustomType({\n\t\t\t\t\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing types... (${pushed}/${ids.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all types\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing documents...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushDocuments) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-documents used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\t\t\t\"Repository selection must be available through context to run `syncDataWithPrismic`\",\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst documentsRead = await this.readDocuments();\n\n\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\tdocumentsRead === undefined ||\n\t\t\t\t\t\t\t\t\t\tdocumentsRead.documents.length === 0\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tconst { signature, documents, directoryPath } = documentsRead;\n\n\t\t\t\t\t\t\t\t\t// TODO: Replace `unknown` with a Prismic document type.\n\t\t\t\t\t\t\t\t\t// The exact format is not know at this time, hence the `unknown`.\n\t\t\t\t\t\t\t\t\tconst recordDocument: Record<string, unknown> = {};\n\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tdocuments.map(async (documentPath) => {\n\t\t\t\t\t\t\t\t\t\t\tconst filename = path.basename(documentPath, \".json\");\n\t\t\t\t\t\t\t\t\t\t\tconst fileContent = await fs.readFile(\n\t\t\t\t\t\t\t\t\t\t\t\tpath.resolve(directoryPath, documentPath),\n\t\t\t\t\t\t\t\t\t\t\t\t\"utf-8\",\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\t\t// TOOD: Validate the contents of the JSON file and skip on invalid documents.\n\t\t\t\t\t\t\t\t\t\t\t\tconst parsedContents = JSON.parse(fileContent);\n\n\t\t\t\t\t\t\t\t\t\t\t\trecordDocument[filename] = parsedContents;\n\t\t\t\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t\t\t\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t\t\t\t\t`Skipped document due to its invalid format: ${documentPath}`,\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tawait this.manager.prismicRepository.pushDocuments({\n\t\t\t\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\t\t\t\tdocuments: recordDocument,\n\t\t\t\t\t\t\t\t\t\tsignature,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\ttask.title = \"Pushed all documents\";\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Cleaning up data push artifacts\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst root = await this.manager.project.getRoot();\n\t\t\t\t\t\t\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tawait fs.rm(documentsDirectoryPath, {\n\t\t\t\t\t\t\t\t\t\tforce: true,\n\t\t\t\t\t\t\t\t\t\trecursive: true,\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t// Noop, it's not that big of a deal if we cannot delete this directory\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Cleaned up data push artifacts\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pulling existing types...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (ids && ids.length > 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"Types already exist\");\n\t\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst remoteTypes =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.fetchRemoteCustomTypes();\n\n\t\t\t\t\t\t\t\tconst createCustomTypeLimit = pLimit(8);\n\n\t\t\t\t\t\t\t\tlet pulled = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (0/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tremoteTypes.map(async (model) => {\n\t\t\t\t\t\t\t\t\t\tawait createCustomTypeLimit(() =>\n\t\t\t\t\t\t\t\t\t\t\tthis.manager.customTypes.createCustomType({ model }),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\tpulled++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (${pulled}/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pulled existing types\";\n\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializeProject(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Initializing project...\",\n\t\t\t\ttask: async (_, parentTask) =>\n\t\t\t\t\t// We return another Listr instance in the event we have additional task to perform to initialize the project\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: `Patching ${chalk.cyan(\"package.json\")} scripts...`,\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst pkgPath = path.join(this.manager.cwd, \"package.json\");\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst pkgRaw = await fs.readFile(pkgPath, \"utf-8\");\n\t\t\t\t\t\t\t\t\tconst pkg = JSON.parse(pkgRaw);\n\n\t\t\t\t\t\t\t\t\tpkg.scripts ||= {};\n\n\t\t\t\t\t\t\t\t\tif (!pkg.scripts[START_SCRIPT_KEY]) {\n\t\t\t\t\t\t\t\t\t\tpkg.scripts[START_SCRIPT_KEY] = START_SCRIPT_VALUE;\n\n\t\t\t\t\t\t\t\t\t\t// Cheap indent detection based on https://github.com/sindresorhus/detect-indent (simplified because we're only dealing with JSON here)\n\t\t\t\t\t\t\t\t\t\tconst firstIndent = pkgRaw\n\t\t\t\t\t\t\t\t\t\t\t.split(\"\\n\")\n\t\t\t\t\t\t\t\t\t\t\t.find((line) => line.match(/^(?:( )+|\\t+)/));\n\t\t\t\t\t\t\t\t\t\tconst indent = firstIndent?.match(/^(?:( )+|\\t+)/)?.[0];\n\n\t\t\t\t\t\t\t\t\t\tawait fs.writeFile(\n\t\t\t\t\t\t\t\t\t\t\tpkgPath,\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(\n\t\t\t\t\t\t\t\t\t\t\t\tpkg,\n\t\t\t\t\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t\t\t\t\tindent && indent !== \" \" ? indent : \" \",\n\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\t!pkg.scripts[\"slicemachine\"].startsWith(START_SCRIPT_VALUE)\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tthrow new Error(\"Script already exists\");\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t\t\t\ttask.title = `Could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts (warning)`;\n\t\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts)`;\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tthis.context.projectInitialization ||= {};\n\t\t\t\t\t\t\t\tthis.context.projectInitialization.patchedScript = true;\n\n\t\t\t\t\t\t\t\ttask.title = `Patched ${chalk.cyan(\"package.json\")} scripts`;\n\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (patched ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t)} scripts)`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializePlugins(): Promise<void> {\n\t\treturn listrRun(\n\t\t\t[\n\t\t\t\t{\n\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t// title: \"Initializing plugins...\",\n\t\t\t\t\ttitle: \"Initializing adapter...\",\n\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\tconst updateOutput = (data: Buffer | string | null) => {\n\t\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t\t} else if (typeof data === \"string\") {\n\t\t\t\t\t\t\t\ttask.output = data;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tawait this.manager.project.initProject({\n\t\t\t\t\t\t\tlog: updateOutput,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t// task.title = \"Initialized plugins\";\n\t\t\t\t\t\ttask.title = \"Initialized adapter\";\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t\t{ exitOnError: false },\n\t\t).catch(() => void 0);\n\t}\n}\n"],"names":["updateSentryContext","trackSentryError","createSliceMachineManager","setupSentry","pkg","assertExists","getRunScriptCommand","getExecuteCommand","prompt","execaCommand","listrRun","downloadTemplate","GIGET_PROVIDER","GIGET_ORGANIZATION","fs","getRandomRepositoryDomain","listr","_","detectFramework","detectStarterId","_b","_a","formatRepositoryDomain","validateRepositoryDomainAndAvailability","domain","getErrorMessageForRepositoryDomainValidation","validateRepositoryDomain","path","maybeSuggestion","REPOSITORY_NAME_VALIDATION","globby","SLICE_MACHINE_INIT_USER_AGENT","pLimit","START_SCRIPT_KEY","START_SCRIPT_VALUE"],"mappings":"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"}
1
+ {"version":3,"file":"SliceMachineInitProcess.cjs","sources":["../../src/SliceMachineInitProcess.ts"],"sourcesContent":["import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\n\nimport chalk from \"chalk\";\n\nimport { execaCommand, type ExecaChildProcess } from \"execa\";\n\nimport open from \"open\";\nimport logSymbols from \"log-symbols\";\nimport { globby } from \"globby\";\nimport { downloadTemplate } from \"giget\";\nimport pLimit from \"p-limit\";\n\nimport {\n\tcreateSliceMachineManager,\n\tPrismicUserProfile,\n\tPrismicRepository,\n\tSliceMachineManager,\n\tPackageManager,\n\tStarterId,\n\tREPOSITORY_NAME_VALIDATION,\n} from \"@slicemachine/manager\";\n\nimport pkg from \"../package.json\";\nimport { detectFramework, Framework } from \"./lib/framework\";\nimport { getRunScriptCommand } from \"./lib/getRunScriptCommand\";\nimport { getExecuteCommand } from \"./lib/getExecuteCommand\";\nimport {\n\tgetRandomRepositoryDomain,\n\tformatRepositoryDomain,\n\tvalidateRepositoryDomain,\n\tvalidateRepositoryDomainAndAvailability,\n\tgetErrorMessageForRepositoryDomainValidation,\n} from \"./lib/repositoryDomain\";\nimport { listr, listrRun } from \"./lib/listr\";\nimport { prompt } from \"./lib/prompt\";\nimport { assertExists } from \"./lib/assertExists\";\nimport {\n\tGIGET_ORGANIZATION,\n\tGIGET_PROVIDER,\n\tSLICE_MACHINE_INIT_USER_AGENT,\n\tSTART_SCRIPT_KEY,\n\tSTART_SCRIPT_VALUE,\n} from \"./constants\";\nimport { detectStarterId } from \"./lib/starters\";\nimport { setupSentry } from \"./lib/setupSentry\";\nimport { trackSentryError } from \"./lib/sentryErrorHandlers\";\nimport { updateSentryContext } from \"./lib/updateSentryContext\";\n\nexport type SliceMachineInitProcessOptions = {\n\trepository?: string;\n\tstarter?: string;\n\tdirectoryName?: string;\n\tpush?: boolean;\n\tpushSlices?: boolean;\n\tpushCustomTypes?: boolean;\n\tpushDocuments?: boolean;\n\tstartSlicemachine?: boolean;\n\tcwd?: string;\n} & Record<string, unknown>;\n\nconst DEFAULT_OPTIONS: SliceMachineInitProcessOptions = {\n\tpush: true,\n\tpushSlices: true,\n\tpushCustomTypes: true,\n\tpushDocuments: true,\n\tstartSlicemachine: true,\n};\n\nexport const createSliceMachineInitProcess = (\n\toptions?: SliceMachineInitProcessOptions,\n): SliceMachineInitProcess => {\n\treturn new SliceMachineInitProcess(options);\n};\n\ntype SliceMachineInitProcessContext = {\n\tframework?: Framework;\n\tpackageManager?: PackageManager;\n\tinstallProcess?: ExecaChildProcess;\n\tuserProfile?: PrismicUserProfile;\n\tuserRepositories?: PrismicRepository[];\n\trepository?: {\n\t\tdomain: string;\n\t\texists: boolean;\n\t};\n\tprojectInitialization?: {\n\t\tpatchedScript?: boolean;\n\t};\n\tstarterId?: StarterId;\n};\n\nexport class SliceMachineInitProcess {\n\tprotected options: SliceMachineInitProcessOptions;\n\tprotected manager: SliceMachineManager;\n\n\tprotected context: SliceMachineInitProcessContext;\n\n\tconstructor(options?: SliceMachineInitProcessOptions) {\n\t\tthis.options = { ...DEFAULT_OPTIONS, ...options };\n\t\tthis.manager = createSliceMachineManager({ cwd: options?.cwd });\n\n\t\tthis.context = {};\n\t}\n\n\tasync run(): Promise<void> {\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGray(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"β†’\",\n\t\t\t)} Initializing\\n`,\n\t\t);\n\n\t\ttry {\n\t\t\ttry {\n\t\t\t\tawait setupSentry();\n\t\t\t} catch (error) {\n\t\t\t\t// noop - We don't want to stop the user from using Slice Machine\n\t\t\t\t// because of failed tracking set up. We probably couldn't determine the\n\t\t\t\t// Sentry environment.\n\t\t\t}\n\t\t\tif (this.options.starter) {\n\t\t\t\tawait this.copyStarter();\n\t\t\t} else if (this.options.directoryName) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${logSymbols.warning} --directory-name has no effect because --starter is not specified\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (await this.manager.telemetry.checkIsTelemetryEnabled()) {\n\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\tconsole.log(\n\t\t\t\t\t`${\n\t\t\t\t\t\tlogSymbols.info\n\t\t\t\t\t} We collect telemetry data to improve user experience.\\n Learn more: ${chalk.cyan(\n\t\t\t\t\t\t\"https://prismic.dev/slice-machine/telemetry\",\n\t\t\t\t\t)}\\n`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tawait this.manager.telemetry.initTelemetry({\n\t\t\t\tappName: pkg.name,\n\t\t\t\tappVersion: pkg.version,\n\t\t\t});\n\n\t\t\tawait this.manager.telemetry.track({\n\t\t\t\tevent: \"command:init:start\",\n\t\t\t\trepository: this.options.repository,\n\t\t\t});\n\n\t\t\tawait this.detectEnvironment();\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.framework,\n\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.beginCoreDependenciesInstallation();\n\n\t\t\tif (this.options.repository) {\n\t\t\t\tawait this.useRepositoryFlag();\n\t\t\t} else {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tawait this.selectRepository();\n\t\t\t}\n\n\t\t\tassertExists(\n\t\t\t\tthis.context.repository,\n\t\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t\t);\n\n\t\t\tawait this.finishCoreDependenciesInstallation();\n\t\t\tawait this.upsertSliceMachineConfigurationAndStartPluginRunner();\n\n\t\t\tconst isLoginRequired = await this.checkIsLoginRequired();\n\t\t\tif (isLoginRequired) {\n\t\t\t\tawait this.loginAndFetchUserData();\n\t\t\t\tif (this.context.repository.exists) {\n\t\t\t\t\tthis.validateWriteAccess();\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!this.context.repository.exists) {\n\t\t\t\tawait this.createNewRepository();\n\t\t\t\tawait this.setDefaultMasterLocale();\n\t\t\t}\n\n\t\t\tawait this.syncDataWithPrismic();\n\t\t\tawait this.initializeProject();\n\t\t\tawait this.initializePlugins();\n\t\t\tawait this.completeOnboardingSteps();\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\n\t\t\tthrow error;\n\t\t}\n\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework.sliceMachineTelemetryID,\n\t\t\trepository: this.context.repository.domain,\n\t\t\tsuccess: true,\n\t\t});\n\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`\\n${chalk.bgGreen(` ${chalk.bold.white(\"Slice Machine\")} `)} ${chalk.dim(\n\t\t\t\t\"β†’\",\n\t\t\t)} Initialization successful!\n\nContinue with next steps in Slice Machine.\n`,\n\t\t);\n\n\t\ttry {\n\t\t\tif (this.options.startSlicemachine) {\n\t\t\t\tconst runSmCommand = this.context.projectInitialization?.patchedScript\n\t\t\t\t\t? await getRunScriptCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"slicemachine\",\n\t\t\t\t\t })\n\t\t\t\t\t: await getExecuteCommand({\n\t\t\t\t\t\t\tagent: this.context.packageManager || \"npm\",\n\t\t\t\t\t\t\tscript: \"start-slicemachine\",\n\t\t\t\t\t });\n\n\t\t\t\tconst { startSlicemachine } = await prompt<\n\t\t\t\t\tboolean,\n\t\t\t\t\t\"startSlicemachine\"\n\t\t\t\t>({\n\t\t\t\t\ttype: \"confirm\",\n\t\t\t\t\tname: \"startSlicemachine\",\n\t\t\t\t\tmessage: `Run Slice Machine (${chalk.cyan(runSmCommand)})?`,\n\t\t\t\t\tinitial: true,\n\t\t\t\t});\n\n\t\t\t\tif (startSlicemachine) {\n\t\t\t\t\tconst commandReturnValue = await execaCommand(runSmCommand, {\n\t\t\t\t\t\tenv: { FORCE_COLOR: \"true\" },\n\t\t\t\t\t}).pipeStdout?.(process.stdout);\n\t\t\t\t\tif (commandReturnValue !== undefined) {\n\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\tconsole.log(commandReturnValue.stdout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\t// Only track this error with Sentry, it's only the final convenience message\n\t\t\tawait this.trackSentryError(error);\n\t\t}\n\t}\n\n\tprotected async checkIsLoginRequired(): Promise<boolean> {\n\t\ttry {\n\t\t\tassertExists(this.context.repository, \"\");\n\t\t\tif (this.context.repository.exists === false) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tconst [slices, ctLibrary, documentsGlob] = await Promise.all([\n\t\t\t\tthis.readAllSlices(),\n\t\t\t\tthis.manager.customTypes.readCustomTypeLibrary(),\n\t\t\t\tthis.readDocuments(),\n\t\t\t]);\n\n\t\t\t// If repository exists, and there's anything to push\n\t\t\tif (\n\t\t\t\tslices.length > 0 ||\n\t\t\t\tctLibrary.ids.length > 0 ||\n\t\t\t\t(documentsGlob !== undefined && documentsGlob.documents.length > 0)\n\t\t\t) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\t// If repository exists, and there might be things to pull\n\t\t\tif (ctLibrary.ids.length === 0) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tprotected trackError = async (error: unknown): Promise<void> => {\n\t\tawait this.trackSentryError(error);\n\t\tawait this.trackTelemetryError(error);\n\t};\n\n\tprotected trackTelemetryError = async (error: unknown): Promise<void> => {\n\t\t// Transform error to string and prevent hitting Segment 500kb API limit or sending ridiculously long trace\n\t\tconst safeError = (\n\t\t\terror instanceof Error ? error.message : `${error}`\n\t\t).slice(0, 512);\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:end\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t\trepository: this.context.repository?.domain || \"\",\n\t\t\tsuccess: false,\n\t\t\terror: safeError,\n\t\t});\n\t};\n\n\tprotected trackSentryError = async (error: unknown): Promise<void> => {\n\t\tawait updateSentryContext({\n\t\t\tmanager: this.manager,\n\t\t\trepositoryName: this.context.repository?.domain || \"\",\n\t\t\tframework: this.context.framework?.sliceMachineTelemetryID ?? \"unknown\",\n\t\t});\n\t\ttrackSentryError(error);\n\t};\n\n\tprotected async copyStarter(): Promise<void> {\n\t\tconst dir = await this.getStarterDirectoryName();\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Copying starter...\\n\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tconst starter = this.options.starter;\n\n\t\t\t\t\tawait downloadTemplate(\n\t\t\t\t\t\t`${GIGET_PROVIDER}:${GIGET_ORGANIZATION}/${starter}#HEAD`,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tdir,\n\t\t\t\t\t\t},\n\t\t\t\t\t);\n\n\t\t\t\t\tprocess.chdir(dir);\n\t\t\t\t\tthis.manager.cwd = process.cwd();\n\n\t\t\t\t\ttask.title = \"Starter copied\\n\";\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async getStarterDirectoryName(): Promise<string> {\n\t\tlet directoryName: string;\n\t\tconst folderNames = await fs.readdir(process.cwd());\n\n\t\tif (\n\t\t\tthis.options.directoryName &&\n\t\t\t!folderNames.includes(this.options.directoryName)\n\t\t) {\n\t\t\t// Use provided directory\n\t\t\tdirectoryName = this.options.directoryName;\n\t\t} else if (\n\t\t\tthis.options.repository &&\n\t\t\t!folderNames.includes(this.options.repository)\n\t\t) {\n\t\t\t// Use repository name\n\t\t\tdirectoryName = this.options.repository;\n\t\t} else {\n\t\t\t// Use random name\n\t\t\tlet suggestedName: string;\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (folderNames.includes(suggestedName));\n\n\t\t\tconst { selectedDirectory } = await prompt<string, \"selectedDirectory\">({\n\t\t\t\ttype: \"text\",\n\t\t\t\tname: \"selectedDirectory\",\n\t\t\t\tmessage: \"Your starter directory name\",\n\t\t\t\tinitial: suggestedName,\n\t\t\t\tvalidate: async (rawDirectory: string) => {\n\t\t\t\t\tif (folderNames.includes(rawDirectory)) {\n\t\t\t\t\t\treturn \"Directory name already exists\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tdirectoryName = selectedDirectory;\n\t\t}\n\n\t\treturn directoryName;\n\t}\n\n\tprotected detectEnvironment(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Detecting environment...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting framework...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.framework = await detectFramework(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting package manager...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.packageManager =\n\t\t\t\t\t\t\t\t\tawait this.manager.project.detectPackageManager({\n\t\t\t\t\t\t\t\t\t\troot: this.manager.cwd,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\ttask.title = `Detected package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\t\t\t\"Project framework must be available through context to proceed\",\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tparentTask.title = `Detected framework ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.framework.name,\n\t\t\t\t\t\t\t\t)} and package manager ${chalk.cyan(\n\t\t\t\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Detecting starter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tthis.context.starterId = await detectStarterId(\n\t\t\t\t\t\t\t\t\tthis.manager.cwd,\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\tif (this.context.starterId) {\n\t\t\t\t\t\t\t\t\ttask.title = `Detected starter ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.starterId,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\ttask.title = \"No starter detected\";\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected beginCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Beginning core dependencies installation...\",\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t\t\"Project package manager must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `beginCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst { execaProcess } =\n\t\t\t\t\t\tawait this.manager.project.installDependencies({\n\t\t\t\t\t\t\tpackageManager: this.context.packageManager,\n\t\t\t\t\t\t\tdependencies: this.context.framework.devDependencies,\n\t\t\t\t\t\t\tdev: true,\n\t\t\t\t\t\t\t// Picked up later\n\t\t\t\t\t\t\tlog: () => {\n\t\t\t\t\t\t\t\t/* ... */\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\n\t\t\t\t\t// Fail hard if process fails\n\t\t\t\t\texecaProcess.catch(async (error) => {\n\t\t\t\t\t\tconst [_, ...argv1n] = process.argv;\n\t\t\t\t\t\t// Command the user used\n\t\t\t\t\t\tlet tryAgainCommand = [process.argv0, ...argv1n].join(\" \");\n\n\t\t\t\t\t\t// If the `repository` option wasn't used AND the repository was selected/created\n\t\t\t\t\t\tif (!this.options.repository && this.context.repository) {\n\t\t\t\t\t\t\ttryAgainCommand = `${tryAgainCommand} --repository=${this.context.repository.domain}`;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tawait this.trackError(error);\n\t\t\t\t\t\tconsole.error(\n\t\t\t\t\t\t\t`\\n\\n${error.shortMessage}\\n${error.stderr}\\n\\n${\n\t\t\t\t\t\t\t\tlogSymbols.error\n\t\t\t\t\t\t\t} Dependency installation failed, try again with:\\n\\n ${chalk.gray(\n\t\t\t\t\t\t\t\t\"$\",\n\t\t\t\t\t\t\t)} ${chalk.cyan(tryAgainCommand)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tprocess.exit(1);\n\t\t\t\t\t});\n\n\t\t\t\t\tthis.context.installProcess = execaProcess;\n\n\t\t\t\t\ttask.title = `Began core dependencies installation with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)} ... (running in background)`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async fetchUserProfile(): Promise<void> {\n\t\tthis.context.userProfile = await this.manager.user.getProfile();\n\n\t\tawait this.manager.telemetry.identify({\n\t\t\tuserID: this.context.userProfile.shortId,\n\t\t\tintercomHash: this.context.userProfile.intercomHash,\n\t\t});\n\t\tawait this.manager.telemetry.track({\n\t\t\tevent: \"command:init:identify\",\n\t\t\trepository: this.options.repository,\n\t\t});\n\t}\n\n\tprotected async fetchUserRepositories(): Promise<void> {\n\t\tthis.context.userRepositories =\n\t\t\tawait this.manager.prismicRepository.readAll();\n\t}\n\n\tprotected validateWriteAccess(): void {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to validate write access\",\n\t\t);\n\t\tconst { domain } = this.context.repository;\n\t\tconst maybeRepository = this.context.userRepositories.find(\n\t\t\t(repository) => repository.domain === domain,\n\t\t);\n\n\t\tif (maybeRepository) {\n\t\t\tif (!this.manager.prismicRepository.hasWriteAccess(maybeRepository)) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Cannot run init command with repository ${chalk.cyan(\n\t\t\t\t\t\tmaybeRepository.domain,\n\t\t\t\t\t)}: you are not a developer or admin of this repository`,\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot validate write access for repository ${chalk.cyan(\n\t\t\t\t\tdomain,\n\t\t\t\t)}: you are not part of this repository`,\n\t\t\t);\n\t\t}\n\t}\n\n\tprotected getLoggingInTitle(subtitle?: string, ...extra: string[]): string {\n\t\treturn `Logging in to Prismic...\n\t\t\nβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ\n\n${subtitle ? `* * ${subtitle}` : \"\"}\n${extra.length ? `\\n${extra.map((line) => ` ${line}`).join(\"\\n\")}\\n` : \"\"}\nβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ\n`;\n\t}\n\n\tprotected loginAndFetchUserData(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: this.getLoggingInTitle(),\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\"Validating session...\");\n\t\t\t\t\tconst isLoggedIn = await this.manager.user.checkIsLoggedIn();\n\n\t\t\t\t\tif (!isLoggedIn) {\n\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\tchalk.cyan(\"Press any key to open the browser to login...\"),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\tawait this.waitingForLogin(({ url }) => {\n\t\t\t\t\t\t\tparentTask.title = this.getLoggingInTitle(\n\t\t\t\t\t\t\t\tchalk.cyan(\"Opening browser, waiting for you to login...\"),\n\t\t\t\t\t\t\t\tchalk.yellow(\n\t\t\t\t\t\t\t\t\t\"If your browser did not open automatically, please use the url below:\",\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\turl,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tparentTask.title = `Logged in`;\n\n\t\t\t\t\treturn listr(\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user profile...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserProfile();\n\t\t\t\t\t\t\t\t\tparentTask.title = `Logged in as ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\tthis.context.userProfile?.email,\n\t\t\t\t\t\t\t\t\t)}`;\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user profile\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttitle: \"Fetching user repositories...\",\n\t\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\t\tawait this.fetchUserRepositories();\n\t\t\t\t\t\t\t\t\ttask.title = \"Fetched user repositories\";\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t],\n\t\t\t\t\t\t{ concurrent: true },\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async pressKeyToLogin(): Promise<void> {\n\t\tawait new Promise((resolve) => {\n\t\t\tconst initialRawMode = !!process.stdin.isRaw;\n\t\t\tprocess.stdin.setRawMode?.(true);\n\t\t\tprocess.stdin.resume();\n\t\t\tprocess.stdin.once(\"data\", (data: Buffer) => {\n\t\t\t\tprocess.stdin.setRawMode?.(initialRawMode);\n\t\t\t\tprocess.stdin.pause();\n\t\t\t\tresolve(data.toString(\"utf-8\"));\n\t\t\t});\n\t\t});\n\t}\n\n\tprotected async waitingForLogin(\n\t\tonListenCallback?: (\n\t\t\tsessionInfo: Awaited<\n\t\t\t\tReturnType<typeof this.manager.user.getLoginSessionInfo>\n\t\t\t>,\n\t\t) => void,\n\t): Promise<void> {\n\t\tconst sessionInfo = await this.manager.user.getLoginSessionInfo();\n\t\tawait this.manager.user.nodeLoginSession({\n\t\t\tport: sessionInfo.port,\n\t\t\tonListenCallback() {\n\t\t\t\topen(sessionInfo.url);\n\t\t\t\tonListenCallback?.(sessionInfo);\n\t\t\t},\n\t\t});\n\t}\n\n\tprotected useRepositoryFlag(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Flag ${chalk.cyan(\"repository\")} used, validating input...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.options.repository,\n\t\t\t\t\t\t\"Flag `repository` must be set to run `useRepositoryFlag`\",\n\t\t\t\t\t);\n\t\t\t\t\tconst domain = formatRepositoryDomain(this.options.repository);\n\t\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t\t});\n\n\t\t\t\t\tif (validation.LessThanMin || validation.MoreThanMax) {\n\t\t\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\t\t\tvalidation: {\n\t\t\t\t\t\t\t\t...validation,\n\t\t\t\t\t\t\t\t// We don't want to throw if repo already exists.\n\t\t\t\t\t\t\t\t// User most probably just created it via their dashboard.\n\t\t\t\t\t\t\t\tAlreadyExists: false,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (errorMessage) {\n\t\t\t\t\t\t\tthrow new Error(errorMessage);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Selected repository ${chalk.cyan(\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t)} (flag ${chalk.cyan(\"repository\")} used)`;\n\n\t\t\t\t\tthis.context.repository = {\n\t\t\t\t\t\tdomain,\n\t\t\t\t\t\texists: validation.AlreadyExists ?? false,\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async selectRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `selectRepository`\",\n\t\t);\n\n\t\tif (this.context.userRepositories.length) {\n\t\t\tawait this.trySelectExistingRepository();\n\t\t}\n\n\t\tif (!this.context.repository) {\n\t\t\tawait this.selectNewRepository();\n\t\t}\n\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to proceed\",\n\t\t);\n\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t// eslint-disable-next-line no-console\n\t\tconsole.log(\n\t\t\t`${logSymbols.success} Selected repository ${chalk.cyan(\n\t\t\t\tthis.context.repository.domain,\n\t\t\t)}`,\n\t\t);\n\t}\n\n\tprotected async trySelectExistingRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.userRepositories,\n\t\t\t\"User repositories must be available through context to run `trySelectExistingRepository`\",\n\t\t);\n\n\t\tconst { maybeDomain } = await prompt<string, \"maybeDomain\">({\n\t\t\ttype: \"select\",\n\t\t\tname: \"maybeDomain\",\n\t\t\tmessage: \"Pick a repository to connect to or choose to create a new one\",\n\t\t\twarn: \"You are not a developer or admin of this repository\",\n\t\t\tchoices: [\n\t\t\t\t{\n\t\t\t\t\ttitle: \"CREATE NEW\",\n\t\t\t\t\tdescription: \"Create a new Prismic repository\\n\",\n\t\t\t\t\tvalue: \"\",\n\t\t\t\t},\n\t\t\t\t...this.context.userRepositories\n\t\t\t\t\t.map((repository) => {\n\t\t\t\t\t\tconst hasWriteAccess =\n\t\t\t\t\t\t\tthis.manager.prismicRepository.hasWriteAccess(repository);\n\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\ttitle: `${repository.domain}${\n\t\t\t\t\t\t\t\thasWriteAccess ? \"\" : \" (Unauthorized)\"\n\t\t\t\t\t\t\t}`,\n\t\t\t\t\t\t\tdescription: `Connect to ${chalk.cyan(repository.domain)}`,\n\t\t\t\t\t\t\tvalue: repository.domain,\n\t\t\t\t\t\t\tdisabled: !hasWriteAccess,\n\t\t\t\t\t\t};\n\t\t\t\t\t})\n\t\t\t\t\t.sort((a, b) => (a.value > b.value ? 1 : -1)),\n\t\t\t],\n\t\t});\n\n\t\tif (maybeDomain) {\n\t\t\tthis.context.repository = {\n\t\t\t\tdomain: maybeDomain,\n\t\t\t\texists: true,\n\t\t\t};\n\t\t}\n\t}\n\n\tprotected async selectNewRepository(): Promise<void> {\n\t\tlet suggestedName = \"\";\n\n\t\t// TODO: Improve concurrency\n\t\tconst trySuggestName = async (name: string): Promise<string | void> => {\n\t\t\tif (name) {\n\t\t\t\tconst formattedName = formatRepositoryDomain(name);\n\n\t\t\t\tif (\n\t\t\t\t\t!validateRepositoryDomain({ domain: formattedName }).hasErrors &&\n\t\t\t\t\t!(await this.manager.prismicRepository.checkExists({\n\t\t\t\t\t\tdomain: formattedName,\n\t\t\t\t\t}))\n\t\t\t\t) {\n\t\t\t\t\treturn formattedName;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// 1. Try to suggest name after directory name\n\t\tconst maybeSuggestion = await trySuggestName(\n\t\t\tpath.basename(this.manager.cwd),\n\t\t);\n\t\tif (maybeSuggestion) {\n\t\t\tsuggestedName = maybeSuggestion;\n\t\t}\n\n\t\t// 2. Try to suggest name after package name\n\t\tif (!suggestedName) {\n\t\t\ttry {\n\t\t\t\tconst pkgJSONPath = path.join(this.manager.cwd, \"package.json\");\n\t\t\t\tconst pkg = JSON.parse(await fs.readFile(pkgJSONPath, \"utf-8\"));\n\n\t\t\t\tconst maybeSuggestion = await trySuggestName(pkg.name);\n\t\t\t\tif (maybeSuggestion) {\n\t\t\t\t\tsuggestedName = maybeSuggestion;\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Noop\n\t\t\t}\n\t\t}\n\n\t\t// 3. Use random name\n\t\tif (!suggestedName) {\n\t\t\tdo {\n\t\t\t\tsuggestedName = getRandomRepositoryDomain();\n\t\t\t} while (\n\t\t\t\tawait this.manager.prismicRepository.checkExists({\n\t\t\t\t\tdomain: suggestedName,\n\t\t\t\t})\n\t\t\t);\n\t\t}\n\n\t\tconst { domain } = await prompt<string, \"domain\">({\n\t\t\ttype: \"text\",\n\t\t\tname: \"domain\",\n\t\t\t// Overriden by the `onRender` function, just used as a fallback\n\t\t\tmessage: \"Choose a name for your Prismic repository\",\n\t\t\tinitial: suggestedName,\n\t\t\tonRender() {\n\t\t\t\tconst rawDomain = this.value || this.initial || \"\";\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = validateRepositoryDomain({ domain });\n\n\t\t\t\tconst minRule = validation.LessThanMin\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Min + \" characters long or more\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tconst maxRule = validation.MoreThanMax\n\t\t\t\t\t? chalk.red(\n\t\t\t\t\t\t\t`1. Name must be ${chalk.bold(\n\t\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t )\n\t\t\t\t\t: `1. Name must be ${chalk.cyan(\n\t\t\t\t\t\t\tREPOSITORY_NAME_VALIDATION.Max + \" characters long or less\",\n\t\t\t\t\t )}`;\n\n\t\t\t\tthis.msg = chalk.reset(\n\t\t\t\t\t`\nChoose a name for your Prismic repository\n\n NAMING RULES\n ${minRule}\n ${maxRule}\n 3. Name will be ${chalk.cyan(\"kebab-cased\")} automatically\n\n CONSIDERATIONS\n 1. Once picked, your repository name ${chalk.cyan(\"cannot be changed\")}\n 2. A ${chalk.cyan(\n\t\t\t\"display name\",\n\t\t)} for the repository can be configured later on\n\n PREVIEW\n Dashboard ${chalk.cyan(`https://${domain}.prismic.io`)}\n API ${chalk.cyan(`https://${domain}.cdn.prismic.io/api/v2`)}\n\n${chalk.cyan(\"?\")} Your Prismic repository name`.replace(\"\\n\", \"\"),\n\t\t\t\t);\n\t\t\t},\n\t\t\tvalidate: async (rawDomain: string) => {\n\t\t\t\tconst domain = formatRepositoryDomain(rawDomain);\n\t\t\t\tconst validation = await validateRepositoryDomainAndAvailability({\n\t\t\t\t\tdomain,\n\t\t\t\t\texistsFn: (domain) =>\n\t\t\t\t\t\tthis.manager.prismicRepository.checkExists({ domain }),\n\t\t\t\t});\n\t\t\t\tconst errorMessage = getErrorMessageForRepositoryDomainValidation({\n\t\t\t\t\tvalidation,\n\t\t\t\t\tdisplayDomain: chalk.cyan(domain),\n\t\t\t\t});\n\n\t\t\t\treturn errorMessage || true;\n\t\t\t},\n\t\t\tformat: (value) => {\n\t\t\t\treturn formatRepositoryDomain(value);\n\t\t\t},\n\t\t});\n\n\t\t// Clear extra lines\n\t\tprocess.stdout.moveCursor?.(0, -16);\n\t\tprocess.stdout.clearScreenDown?.();\n\n\t\tthis.context.repository = {\n\t\t\tdomain,\n\t\t\texists: false,\n\t\t};\n\t}\n\n\tprotected async completeOnboardingSteps(): Promise<void> {\n\t\ttry {\n\t\t\tconst { value: onboardingExperimentVariant } =\n\t\t\t\t(await this.manager.telemetry.getExperimentVariant(\n\t\t\t\t\t\"shared-onboarding\",\n\t\t\t\t)) ?? {};\n\t\t\tif (onboardingExperimentVariant === \"with-shared-onboarding\") {\n\t\t\t\tthis.manager.prismicRepository.completeOnboardingStep(\n\t\t\t\t\t\"chooseLocale\",\n\t\t\t\t\t\"createProject\",\n\t\t\t\t\t\"setupSliceMachine\",\n\t\t\t\t);\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tawait this.trackError(error);\n\t\t}\n\t}\n\n\tprotected createNewRepository(): Promise<void> {\n\t\tassertExists(\n\t\t\tthis.context.repository,\n\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t);\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Creating new repository ${chalk.cyan(\n\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `createNewRepository`\",\n\t\t\t\t\t);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t// When we have an error here, it's most probably because the user has a stale SESSION cookie\n\n\t\t\t\t\t\t// Ensure to logout user to remove SESSION and prismic-auth cookies\n\t\t\t\t\t\tawait this.manager.user.logout();\n\n\t\t\t\t\t\t// Force a new login to get a brand new cookies value\n\t\t\t\t\t\ttask.output =\n\t\t\t\t\t\t\t\"It seems there is an authentication problem, press any key to open the browser to login again...\";\n\t\t\t\t\t\tawait this.pressKeyToLogin();\n\t\t\t\t\t\ttask.output = \"Browser opened, waiting for you to login...\";\n\t\t\t\t\t\tawait this.waitingForLogin();\n\n\t\t\t\t\t\t// Try to create repository again with the new cookies value\n\t\t\t\t\t\tawait this.manager.prismicRepository.create({\n\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\tframework: this.context.framework.wroomTelemetryID,\n\t\t\t\t\t\t\tstarterId: this.context.starterId,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.context.repository.exists = true;\n\t\t\t\t\ttask.output = \"\";\n\t\t\t\t\ttask.title = `Created new repository ${chalk.cyan(\n\t\t\t\t\t\tthis.context.repository.domain,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async setDefaultMasterLocale(): Promise<void> {\n\t\tconst documentsRead = await this.readDocuments();\n\n\t\tif (documentsRead !== undefined && documentsRead.documents.length > 0) {\n\t\t\t// if there are documents to push, we assume it's a starter which has a master locale already set\n\t\t\treturn;\n\t\t}\n\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Setting main content language...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tawait this.manager.prismicRepository.setDefaultMasterLocale();\n\t\t\t\t\ttask.title = `Main content language set to ${chalk.cyan(\n\t\t\t\t\t\t\"English - United States\",\n\t\t\t\t\t)} πŸ‡ΊπŸ‡Έ. You can change it anytime in your project settings.`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected finishCoreDependenciesInstallation(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: `Finishing core dependencies installation with ${chalk.cyan(\n\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t)} ...`,\n\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.installProcess,\n\t\t\t\t\t\t\"Initial dependencies installation process must be available through context to run `finishCoreDependenciesInstallation`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst updateOutput = (data: Buffer | null) => {\n\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\n\t\t\t\t\t// Don't clutter console with logs when process is non TTY (CI, etc.)\n\t\t\t\t\tif (process.stdout.isTTY || process.env.NODE_ENV === \"test\") {\n\t\t\t\t\t\tthis.context.installProcess.stdout?.on(\"data\", updateOutput);\n\t\t\t\t\t}\n\t\t\t\t\tthis.context.installProcess.stderr?.on(\"data\", updateOutput);\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.context.installProcess;\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * Error catching happens when then process is started ealier so\n\t\t\t\t\t\t * that all install errors, earlier and presents, can be catched.\n\t\t\t\t\t\t *\n\t\t\t\t\t\t * Here, we force the task to wait so that it is neither marked as\n\t\t\t\t\t\t * done or has the opportunity to handle the error itself.\n\t\t\t\t\t\t */\n\t\t\t\t\t\t// If for whatever reason the process is not exited by now, we still throw the error\n\t\t\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 5000));\n\t\t\t\t\t\tthrow error;\n\t\t\t\t\t}\n\n\t\t\t\t\ttask.title = `Installed core dependencies with ${chalk.cyan(\n\t\t\t\t\t\tthis.context.packageManager,\n\t\t\t\t\t)}`;\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected upsertSliceMachineConfigurationAndStartPluginRunner(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Resolving Slice Machine configuration...\",\n\t\t\t\ttask: async (_, parentTask) => {\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.framework,\n\t\t\t\t\t\t\"Project framework must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\t\t\t\t\tassertExists(\n\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\"Repository selection must be available through context to run `upsertSliceMachineConfiguration`\",\n\t\t\t\t\t);\n\n\t\t\t\t\tlet sliceMachineConfigExists = false;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this.manager.project.getSliceMachineConfigPath();\n\t\t\t\t\t\tsliceMachineConfigExists = true;\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// noop, config does not exists, we'll create it\n\t\t\t\t\t}\n\n\t\t\t\t\tif (sliceMachineConfigExists) {\n\t\t\t\t\t\tparentTask.title = \"Updating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst config = await this.manager.project.getSliceMachineConfig();\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t\tparentTask.title = \"Updated Slice Machine configuration\";\n\t\t\t\t\t} else {\n\t\t\t\t\t\tparentTask.title = \"Creating Slice Machine configuration...\";\n\n\t\t\t\t\t\tconst sliceMachineConfigPath =\n\t\t\t\t\t\t\tawait this.manager.project.suggestSliceMachineConfigPath();\n\n\t\t\t\t\t\tawait this.manager.project.writeSliceMachineConfig({\n\t\t\t\t\t\t\tconfig: {\n\t\t\t\t\t\t\t\trepositoryName: this.context.repository.domain,\n\t\t\t\t\t\t\t\tadapter: this.context.framework.adapterName,\n\t\t\t\t\t\t\t\tlibraries: [\"./slices\"],\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tpath: sliceMachineConfigPath,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tparentTask.title = \"Created Slice Machine configuration\";\n\t\t\t\t\t}\n\n\t\t\t\t\treturn listr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t// title: \"Starting plugin runner...\",\n\t\t\t\t\t\t\ttitle: \"Loading adapter...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tawait this.manager.plugins.initPlugins();\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// task.title = \"Started plugin runner\";\n\t\t\t\t\t\t\t\ttask.title = \"Loaded adapter\";\n\t\t\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t\t\t// parentTask.title = `${parentTask.title} and started plugin runner`;\n\t\t\t\t\t\t\t\tparentTask.title = `${parentTask.title} and loaded adapter`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected async readAllSlices(): Promise<\n\t\t{ libraryID: string; sliceID: string }[]\n\t> {\n\t\tconst { libraries, errors } =\n\t\t\tawait this.manager.slices.readAllSliceLibraries();\n\n\t\tif (errors.length > 0) {\n\t\t\t// TODO: Provide better error message.\n\t\t\tthrow new Error(`Failed to read slice libraries: ${errors.join(\", \")}`);\n\t\t}\n\n\t\tconst slices: { libraryID: string; sliceID: string }[] = [];\n\t\tfor (const library of libraries) {\n\t\t\tif (library.sliceIDs) {\n\t\t\t\tfor (const sliceID of library.sliceIDs) {\n\t\t\t\t\tslices.push({\n\t\t\t\t\t\tlibraryID: library.libraryID,\n\t\t\t\t\t\tsliceID,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn slices;\n\t}\n\n\tprotected async readDocuments(): Promise<\n\t\t| {\n\t\t\t\tsignature: string;\n\t\t\t\tdocuments: string[];\n\t\t\t\tdirectoryPath: string;\n\t\t }\n\t\t| undefined\n\t> {\n\t\tconst root = await this.manager.project.getRoot();\n\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\ttry {\n\t\t\tawait fs.access(documentsDirectoryPath);\n\t\t} catch {\n\t\t\treturn;\n\t\t}\n\t\tconst signaturePath = path.resolve(documentsDirectoryPath, \"index.json\");\n\t\tconst rawSignature = await fs.readFile(signaturePath, \"utf-8\");\n\t\tconst signature: string = JSON.parse(rawSignature).signature;\n\n\t\tconst documents = await globby(\"*/*.json\", {\n\t\t\tcwd: documentsDirectoryPath,\n\t\t});\n\n\t\treturn { signature, documents, directoryPath: documentsDirectoryPath };\n\t}\n\n\tprotected syncDataWithPrismic(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Syncing data with Prismic...\",\n\t\t\t\ttask: (_, parentTask) =>\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing slices...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushSlices) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-slices used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst slices = await this.readAllSlices();\n\n\t\t\t\t\t\t\t\tif (slices.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No slice to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushing slices... (initializing ACL)\";\n\t\t\t\t\t\t\t\tawait this.manager.screenshots.initS3ACL();\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (0/${slices.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tslices.map(async (slice) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.slices.pushSlice({\n\t\t\t\t\t\t\t\t\t\t\t...slice,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing slices... (${pushed}/${slices.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all slices\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing types...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushCustomTypes) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-custom-types used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (!ids || ids.length === 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No custom type to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet pushed = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pushing types... (0/${ids.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tids.map(async (id) => {\n\t\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.pushCustomType({\n\t\t\t\t\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\t\t\t\t\tuserAgent: SLICE_MACHINE_INIT_USER_AGENT,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tpushed++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pushing types... (${pushed}/${ids.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pushed all types\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pushing documents...\",\n\t\t\t\t\t\t\tskip: () => {\n\t\t\t\t\t\t\t\tif (!this.options.push) {\n\t\t\t\t\t\t\t\t\treturn `--no-push used`;\n\t\t\t\t\t\t\t\t} else if (!this.options.pushDocuments) {\n\t\t\t\t\t\t\t\t\treturn `--no-push-documents used`;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tassertExists(\n\t\t\t\t\t\t\t\t\tthis.context.repository,\n\t\t\t\t\t\t\t\t\t\"Repository selection must be available through context to run `syncDataWithPrismic`\",\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst documentsRead = await this.readDocuments();\n\n\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\tdocumentsRead === undefined ||\n\t\t\t\t\t\t\t\t\t\tdocumentsRead.documents.length === 0\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tconst { signature, documents, directoryPath } = documentsRead;\n\n\t\t\t\t\t\t\t\t\t// TODO: Replace `unknown` with a Prismic document type.\n\t\t\t\t\t\t\t\t\t// The exact format is not know at this time, hence the `unknown`.\n\t\t\t\t\t\t\t\t\tconst recordDocument: Record<string, unknown> = {};\n\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tdocuments.map(async (documentPath) => {\n\t\t\t\t\t\t\t\t\t\t\tconst filename = path.basename(documentPath, \".json\");\n\t\t\t\t\t\t\t\t\t\t\tconst fileContent = await fs.readFile(\n\t\t\t\t\t\t\t\t\t\t\t\tpath.resolve(directoryPath, documentPath),\n\t\t\t\t\t\t\t\t\t\t\t\t\"utf-8\",\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\t\t// TOOD: Validate the contents of the JSON file and skip on invalid documents.\n\t\t\t\t\t\t\t\t\t\t\t\tconst parsedContents = JSON.parse(fileContent);\n\n\t\t\t\t\t\t\t\t\t\t\t\trecordDocument[filename] = parsedContents;\n\t\t\t\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t\t\t\t// We prefer to manually allow console logs despite the app being a CLI to catch wild/unwanted console logs better\n\t\t\t\t\t\t\t\t\t\t\t\t// eslint-disable-next-line no-console\n\t\t\t\t\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t\t\t\t\t`Skipped document due to its invalid format: ${documentPath}`,\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tawait this.manager.prismicRepository.pushDocuments({\n\t\t\t\t\t\t\t\t\t\tdomain: this.context.repository.domain,\n\t\t\t\t\t\t\t\t\t\tdocuments: recordDocument,\n\t\t\t\t\t\t\t\t\t\tsignature,\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\ttask.title = \"Pushed all documents\";\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\ttask.skip(\"No document to push\");\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Cleaning up data push artifacts\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst root = await this.manager.project.getRoot();\n\t\t\t\t\t\t\t\tconst documentsDirectoryPath = path.resolve(root, \"documents\");\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tawait fs.rm(documentsDirectoryPath, {\n\t\t\t\t\t\t\t\t\t\tforce: true,\n\t\t\t\t\t\t\t\t\t\trecursive: true,\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\t\t\t// Noop, it's not that big of a deal if we cannot delete this directory\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttask.title = \"Cleaned up data push artifacts\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: \"Pulling existing types...\",\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst { ids, errors } =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.readCustomTypeLibrary();\n\n\t\t\t\t\t\t\t\tif (errors.length > 0) {\n\t\t\t\t\t\t\t\t\t// TODO: Provide better error message.\n\t\t\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t\t\t`Failed to read custom type libraries: ${errors.join(\n\t\t\t\t\t\t\t\t\t\t\t\", \",\n\t\t\t\t\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (ids && ids.length > 0) {\n\t\t\t\t\t\t\t\t\ttask.skip(\"Types already exist\");\n\t\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst remoteTypes =\n\t\t\t\t\t\t\t\t\tawait this.manager.customTypes.fetchRemoteCustomTypes();\n\n\t\t\t\t\t\t\t\tconst createCustomTypeLimit = pLimit(8);\n\n\t\t\t\t\t\t\t\tlet pulled = 0;\n\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (0/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\tremoteTypes.map(async (model) => {\n\t\t\t\t\t\t\t\t\t\tawait createCustomTypeLimit(() =>\n\t\t\t\t\t\t\t\t\t\t\tthis.manager.customTypes.createCustomType({ model }),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\tpulled++;\n\t\t\t\t\t\t\t\t\t\ttask.title = `Pulling existing types... (${pulled}/${remoteTypes.length})`;\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\ttask.title = \"Pulled existing types\";\n\t\t\t\t\t\t\t\tparentTask.title = \"Synced data with Prismic\";\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializeProject(): Promise<void> {\n\t\treturn listrRun([\n\t\t\t{\n\t\t\t\ttitle: \"Initializing project...\",\n\t\t\t\ttask: async (_, parentTask) =>\n\t\t\t\t\t// We return another Listr instance in the event we have additional task to perform to initialize the project\n\t\t\t\t\tlistr([\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttitle: `Patching ${chalk.cyan(\"package.json\")} scripts...`,\n\t\t\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\t\t\tconst pkgPath = path.join(this.manager.cwd, \"package.json\");\n\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tconst pkgRaw = await fs.readFile(pkgPath, \"utf-8\");\n\t\t\t\t\t\t\t\t\tconst pkg = JSON.parse(pkgRaw);\n\n\t\t\t\t\t\t\t\t\tpkg.scripts ||= {};\n\n\t\t\t\t\t\t\t\t\tif (!pkg.scripts[START_SCRIPT_KEY]) {\n\t\t\t\t\t\t\t\t\t\tpkg.scripts[START_SCRIPT_KEY] = START_SCRIPT_VALUE;\n\n\t\t\t\t\t\t\t\t\t\t// Cheap indent detection based on https://github.com/sindresorhus/detect-indent (simplified because we're only dealing with JSON here)\n\t\t\t\t\t\t\t\t\t\tconst firstIndent = pkgRaw\n\t\t\t\t\t\t\t\t\t\t\t.split(\"\\n\")\n\t\t\t\t\t\t\t\t\t\t\t.find((line) => line.match(/^(?:( )+|\\t+)/));\n\t\t\t\t\t\t\t\t\t\tconst indent = firstIndent?.match(/^(?:( )+|\\t+)/)?.[0];\n\n\t\t\t\t\t\t\t\t\t\tawait fs.writeFile(\n\t\t\t\t\t\t\t\t\t\t\tpkgPath,\n\t\t\t\t\t\t\t\t\t\t\tJSON.stringify(\n\t\t\t\t\t\t\t\t\t\t\t\tpkg,\n\t\t\t\t\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t\t\t\t\tindent && indent !== \" \" ? indent : \" \",\n\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t\t\t\t!pkg.scripts[\"slicemachine\"].startsWith(START_SCRIPT_VALUE)\n\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\tthrow new Error(\"Script already exists\");\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\t\t\t\ttask.title = `Could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts (warning)`;\n\t\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (could not patch ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t\t)} scripts)`;\n\n\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tthis.context.projectInitialization ||= {};\n\t\t\t\t\t\t\t\tthis.context.projectInitialization.patchedScript = true;\n\n\t\t\t\t\t\t\t\ttask.title = `Patched ${chalk.cyan(\"package.json\")} scripts`;\n\t\t\t\t\t\t\t\tparentTask.title = `Initialized project (patched ${chalk.cyan(\n\t\t\t\t\t\t\t\t\t\"package.json\",\n\t\t\t\t\t\t\t\t)} scripts)`;\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]),\n\t\t\t},\n\t\t]);\n\t}\n\n\tprotected initializePlugins(): Promise<void> {\n\t\treturn listrRun(\n\t\t\t[\n\t\t\t\t{\n\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t// title: \"Initializing plugins...\",\n\t\t\t\t\ttitle: \"Initializing adapter...\",\n\t\t\t\t\ttask: async (_, task) => {\n\t\t\t\t\t\tconst updateOutput = (data: Buffer | string | null) => {\n\t\t\t\t\t\t\tif (data instanceof Buffer) {\n\t\t\t\t\t\t\t\ttask.output = data.toString();\n\t\t\t\t\t\t\t} else if (typeof data === \"string\") {\n\t\t\t\t\t\t\t\ttask.output = data;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tawait this.manager.project.initProject({\n\t\t\t\t\t\t\tlog: updateOutput,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// TODO: Revert when plugin are introduced to users\n\t\t\t\t\t\t// task.title = \"Initialized plugins\";\n\t\t\t\t\t\ttask.title = \"Initialized adapter\";\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t\t{ exitOnError: false },\n\t\t).catch(() => void 0);\n\t}\n}\n"],"names":["updateSentryContext","trackSentryError","createSliceMachineManager","setupSentry","pkg","assertExists","getRunScriptCommand","getExecuteCommand","prompt","execaCommand","listrRun","downloadTemplate","GIGET_PROVIDER","GIGET_ORGANIZATION","fs","getRandomRepositoryDomain","listr","_","detectFramework","detectStarterId","_b","_a","formatRepositoryDomain","validateRepositoryDomainAndAvailability","domain","getErrorMessageForRepositoryDomainValidation","validateRepositoryDomain","path","maybeSuggestion","REPOSITORY_NAME_VALIDATION","globby","SLICE_MACHINE_INIT_USER_AGENT","pLimit","START_SCRIPT_KEY","START_SCRIPT_VALUE"],"mappings":"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"}
@@ -53,7 +53,7 @@ export declare class SliceMachineInitProcess {
53
53
  protected selectRepository(): Promise<void>;
54
54
  protected trySelectExistingRepository(): Promise<void>;
55
55
  protected selectNewRepository(): Promise<void>;
56
- protected completeOnboardingSteps(...steps: string[]): Promise<void>;
56
+ protected completeOnboardingSteps(): Promise<void>;
57
57
  protected createNewRepository(): Promise<void>;
58
58
  protected setDefaultMasterLocale(): Promise<void>;
59
59
  protected finishCoreDependenciesInstallation(): Promise<void>;
@@ -125,6 +125,7 @@ ${chalk.bgGray(` ${chalk.bold.white("Slice Machine")} `)} ${chalk.dim("β†’")} In
125
125
  await this.syncDataWithPrismic();
126
126
  await this.initializeProject();
127
127
  await this.initializePlugins();
128
+ await this.completeOnboardingSteps();
128
129
  } catch (error) {
129
130
  await this.trackError(error);
130
131
  throw error;
@@ -575,11 +576,11 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
575
576
  exists: false
576
577
  };
577
578
  }
578
- async completeOnboardingSteps(...steps) {
579
+ async completeOnboardingSteps() {
579
580
  try {
580
581
  const { value: onboardingExperimentVariant } = await this.manager.telemetry.getExperimentVariant("shared-onboarding") ?? {};
581
582
  if (onboardingExperimentVariant === "with-shared-onboarding") {
582
- this.manager.prismicRepository.completeOnboardingStep(...steps);
583
+ this.manager.prismicRepository.completeOnboardingStep("chooseLocale", "createProject", "setupSliceMachine");
583
584
  }
584
585
  } catch (error) {
585
586
  await this.trackError(error);
@@ -599,7 +600,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
599
600
  framework: this.context.framework.wroomTelemetryID,
600
601
  starterId: this.context.starterId
601
602
  });
602
- await this.completeOnboardingSteps("createProject", "setupSliceMachine");
603
603
  } catch (error) {
604
604
  await this.manager.user.logout();
605
605
  task.output = "It seems there is an authentication problem, press any key to open the browser to login again...";
@@ -622,7 +622,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
622
622
  async setDefaultMasterLocale() {
623
623
  const documentsRead = await this.readDocuments();
624
624
  if (documentsRead !== void 0 && documentsRead.documents.length > 0) {
625
- await this.completeOnboardingSteps("chooseLocale");
626
625
  return;
627
626
  }
628
627
  return listrRun([
@@ -631,7 +630,6 @@ ${chalk.cyan("?")} Your Prismic repository name`.replace("\n", ""));
631
630
  task: async (_, task) => {
632
631
  await this.manager.prismicRepository.setDefaultMasterLocale();
633
632
  task.title = `Main content language set to ${chalk.cyan("English - United States")} πŸ‡ΊπŸ‡Έ. You can change it anytime in your project settings.`;
634
- await this.completeOnboardingSteps("chooseLocale");
635
633
  }
636
634
  }
637
635
  ]);