@sanity/cli 5.9.0-next.8 → 6.0.0-alpha.11
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.
- package/LICENSE +1 -1
- package/README.md +3212 -2
- package/bin/run.cmd +3 -0
- package/bin/run.js +33 -0
- package/codemods/deskRename.js +115 -96
- package/codemods/partsTypeDirective.js +7 -7
- package/codemods/reactIconsV3.js +78 -51
- package/dist/SanityHelp.js +43 -0
- package/dist/SanityHelp.js.map +1 -0
- package/dist/actions/auth/authServer.js +153 -0
- package/dist/actions/auth/authServer.js.map +1 -0
- package/dist/actions/auth/getProviderName.js +15 -0
- package/dist/actions/auth/getProviderName.js.map +1 -0
- package/dist/actions/auth/login/getProvider.js +54 -0
- package/dist/actions/auth/login/getProvider.js.map +1 -0
- package/dist/actions/auth/login/getSSOProvider.js +30 -0
- package/dist/actions/auth/login/getSSOProvider.js.map +1 -0
- package/dist/actions/auth/login/login.js +101 -0
- package/dist/actions/auth/login/login.js.map +1 -0
- package/dist/actions/auth/login/promptProviders.js +23 -0
- package/dist/actions/auth/login/promptProviders.js.map +1 -0
- package/dist/actions/auth/login/samlProviderToLoginProvider.js +15 -0
- package/dist/actions/auth/login/samlProviderToLoginProvider.js.map +1 -0
- package/dist/actions/auth/types.js +7 -0
- package/dist/actions/auth/types.js.map +1 -0
- package/dist/actions/backup/archiveDir.js +43 -0
- package/dist/actions/backup/archiveDir.js.map +1 -0
- package/dist/actions/backup/assertDatasetExist.js +16 -0
- package/dist/actions/backup/assertDatasetExist.js.map +1 -0
- package/dist/actions/backup/backupDownloadDebug.js +4 -0
- package/dist/actions/backup/backupDownloadDebug.js.map +1 -0
- package/dist/actions/backup/cleanupTmpDir.js +19 -0
- package/dist/actions/backup/cleanupTmpDir.js.map +1 -0
- package/dist/actions/backup/constants.js +3 -0
- package/dist/actions/backup/constants.js.map +1 -0
- package/dist/actions/backup/downloadAsset.js +54 -0
- package/dist/actions/backup/downloadAsset.js.map +1 -0
- package/dist/actions/backup/downloadDocument.js +32 -0
- package/dist/actions/backup/downloadDocument.js.map +1 -0
- package/dist/actions/backup/fetchNextBackupPage.js +48 -0
- package/dist/actions/backup/fetchNextBackupPage.js.map +1 -0
- package/dist/actions/backup/progressSpinner.js +40 -0
- package/dist/actions/backup/progressSpinner.js.map +1 -0
- package/dist/actions/build/buildApp.js +159 -0
- package/dist/actions/build/buildApp.js.map +1 -0
- package/dist/actions/build/buildDebug.js +4 -0
- package/dist/actions/build/buildDebug.js.map +1 -0
- package/dist/actions/build/buildStaticFiles.js +82 -0
- package/dist/actions/build/buildStaticFiles.js.map +1 -0
- package/dist/actions/build/buildStudio.js +202 -0
- package/dist/actions/build/buildStudio.js.map +1 -0
- package/dist/actions/build/buildVendorDependencies.js +179 -0
- package/dist/actions/build/buildVendorDependencies.js.map +1 -0
- package/dist/actions/build/checkRequiredDependencies.js +122 -0
- package/dist/actions/build/checkRequiredDependencies.js.map +1 -0
- package/dist/actions/build/checkStudioDependencyVersions.js +154 -0
- package/dist/actions/build/checkStudioDependencyVersions.js.map +1 -0
- package/dist/actions/build/createExternalFromImportMap.js +11 -0
- package/dist/actions/build/createExternalFromImportMap.js.map +1 -0
- package/dist/actions/build/decorateIndexWithAutoGeneratedWarning.js +13 -0
- package/dist/actions/build/decorateIndexWithAutoGeneratedWarning.js.map +1 -0
- package/dist/actions/build/decorateIndexWithBridgeScript.js +17 -0
- package/dist/actions/build/decorateIndexWithBridgeScript.js.map +1 -0
- package/dist/actions/build/determineBasePath.js +20 -0
- package/dist/actions/build/determineBasePath.js.map +1 -0
- package/dist/actions/build/generateWebManifest.js +27 -0
- package/dist/actions/build/generateWebManifest.js.map +1 -0
- package/dist/actions/build/getAppEnvVars.js +9 -0
- package/dist/actions/build/getAppEnvVars.js.map +1 -0
- package/dist/actions/build/getAutoUpdatesImportMap.js +57 -0
- package/dist/actions/build/getAutoUpdatesImportMap.js.map +1 -0
- package/dist/actions/build/getEntryModule.js +46 -0
- package/dist/actions/build/getEntryModule.js.map +1 -0
- package/dist/actions/build/getPossibleDocumentComponentLocations.js +11 -0
- package/dist/actions/build/getPossibleDocumentComponentLocations.js.map +1 -0
- package/dist/actions/build/getStudioEnvVars.js +9 -0
- package/dist/actions/build/getStudioEnvVars.js.map +1 -0
- package/dist/actions/build/getStudioEnvironmentVariables.js +58 -0
- package/dist/actions/build/getStudioEnvironmentVariables.js.map +1 -0
- package/dist/actions/build/getViteConfig.js +180 -0
- package/dist/actions/build/getViteConfig.js.map +1 -0
- package/dist/actions/build/normalizeBasePath.js +9 -0
- package/dist/actions/build/normalizeBasePath.js.map +1 -0
- package/dist/actions/build/renderDocument.js +54 -0
- package/dist/actions/build/renderDocument.js.map +1 -0
- package/dist/actions/build/renderDocument.worker.js +9 -0
- package/dist/actions/build/renderDocument.worker.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/addTimestampImportMapScriptToHtml.js +59 -0
- package/dist/actions/build/renderDocumentWorker/addTimestampImportMapScriptToHtml.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/BasicDocument.js +61 -0
- package/dist/actions/build/renderDocumentWorker/components/BasicDocument.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/DefaultDocument.js +165 -0
- package/dist/actions/build/renderDocumentWorker/components/DefaultDocument.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/Favicons.js +28 -0
- package/dist/actions/build/renderDocumentWorker/components/Favicons.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/GlobalErrorHandler.js +177 -0
- package/dist/actions/build/renderDocumentWorker/components/GlobalErrorHandler.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/NoJavascript.js +51 -0
- package/dist/actions/build/renderDocumentWorker/components/NoJavascript.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentComponent.js +41 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentComponent.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentHtml.js +55 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentHtml.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/renderDocumentWorker.js +31 -0
- package/dist/actions/build/renderDocumentWorker/renderDocumentWorker.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js +30 -0
- package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/types.js +5 -0
- package/dist/actions/build/renderDocumentWorker/types.js.map +1 -0
- package/dist/actions/build/shouldAutoUpdate.js +35 -0
- package/dist/actions/build/shouldAutoUpdate.js.map +1 -0
- package/dist/actions/build/types.js +3 -0
- package/dist/actions/build/types.js.map +1 -0
- package/dist/actions/build/writeFavicons.js +26 -0
- package/dist/actions/build/writeFavicons.js.map +1 -0
- package/dist/actions/build/writeSanityRuntime.js +61 -0
- package/dist/actions/build/writeSanityRuntime.js.map +1 -0
- package/dist/actions/build/writeWebManifest.js +12 -0
- package/dist/actions/build/writeWebManifest.js.map +1 -0
- package/dist/actions/codemods/deskRename.js +18 -0
- package/dist/actions/codemods/deskRename.js.map +1 -0
- package/dist/actions/codemods/index.js +10 -0
- package/dist/actions/codemods/index.js.map +1 -0
- package/dist/actions/codemods/partsTypeDirective.js +27 -0
- package/dist/actions/codemods/partsTypeDirective.js.map +1 -0
- package/dist/actions/codemods/reactIconsV3.js +30 -0
- package/dist/actions/codemods/reactIconsV3.js.map +1 -0
- package/dist/actions/codemods/types.js +3 -0
- package/dist/actions/codemods/types.js.map +1 -0
- package/dist/actions/cors/filterAndValidateOrigin.js +38 -0
- package/dist/actions/cors/filterAndValidateOrigin.js.map +1 -0
- package/dist/actions/dataset/create.js +46 -0
- package/dist/actions/dataset/create.js.map +1 -0
- package/dist/actions/dataset/determineDatasetAclMode.js +36 -0
- package/dist/actions/dataset/determineDatasetAclMode.js.map +1 -0
- package/dist/actions/dataset/processAliasName.js +20 -0
- package/dist/actions/dataset/processAliasName.js.map +1 -0
- package/dist/actions/dataset/validateDatasetAliasName.js +28 -0
- package/dist/actions/dataset/validateDatasetAliasName.js.map +1 -0
- package/dist/actions/dataset/validateDatasetName.js +39 -0
- package/dist/actions/dataset/validateDatasetName.js.map +1 -0
- package/dist/actions/debug/gatherDebugInfo.js +104 -0
- package/dist/actions/debug/gatherDebugInfo.js.map +1 -0
- package/dist/actions/debug/getGlobalConfigLocation.js +7 -0
- package/dist/actions/debug/getGlobalConfigLocation.js.map +1 -0
- package/dist/actions/debug/types.js +3 -0
- package/dist/actions/debug/types.js.map +1 -0
- package/dist/actions/deploy/checkDir.js +31 -0
- package/dist/actions/deploy/checkDir.js.map +1 -0
- package/dist/actions/deploy/createStudioUserApplication.js +59 -0
- package/dist/actions/deploy/createStudioUserApplication.js.map +1 -0
- package/dist/actions/deploy/createUserApplicationForApp.js +56 -0
- package/dist/actions/deploy/createUserApplicationForApp.js.map +1 -0
- package/dist/actions/deploy/deployApp.js +162 -0
- package/dist/actions/deploy/deployApp.js.map +1 -0
- package/dist/actions/deploy/deployDebug.js +4 -0
- package/dist/actions/deploy/deployDebug.js.map +1 -0
- package/dist/actions/deploy/deployStudio.js +134 -0
- package/dist/actions/deploy/deployStudio.js.map +1 -0
- package/dist/actions/deploy/findUserApplicationForApp.js +110 -0
- package/dist/actions/deploy/findUserApplicationForApp.js.map +1 -0
- package/dist/actions/deploy/findUserApplicationForStudio.js +143 -0
- package/dist/actions/deploy/findUserApplicationForStudio.js.map +1 -0
- package/dist/actions/deploy/types.js +3 -0
- package/dist/actions/deploy/types.js.map +1 -0
- package/dist/actions/dev/devAction.js +7 -0
- package/dist/actions/dev/devAction.js.map +1 -0
- package/dist/actions/dev/devDebug.js +4 -0
- package/dist/actions/dev/devDebug.js.map +1 -0
- package/dist/actions/dev/getCoreAppUrl.js +10 -0
- package/dist/actions/dev/getCoreAppUrl.js.map +1 -0
- package/dist/actions/dev/getDevServerConfig.js +28 -0
- package/dist/actions/dev/getDevServerConfig.js.map +1 -0
- package/dist/actions/dev/startAppDevServer.js +57 -0
- package/dist/actions/dev/startAppDevServer.js.map +1 -0
- package/dist/actions/dev/startStudioDevServer.js +154 -0
- package/dist/actions/dev/startStudioDevServer.js.map +1 -0
- package/dist/actions/dev/types.js +3 -0
- package/dist/actions/dev/types.js.map +1 -0
- package/dist/actions/docs/normalizeDocsPath.js +15 -0
- package/dist/actions/docs/normalizeDocsPath.js.map +1 -0
- package/dist/actions/documents/constants.js +3 -0
- package/dist/actions/documents/constants.js.map +1 -0
- package/dist/actions/documents/editor.js +26 -0
- package/dist/actions/documents/editor.js.map +1 -0
- package/dist/actions/documents/types.js +3 -0
- package/dist/actions/documents/types.js.map +1 -0
- package/dist/actions/documents/validate.js +60 -0
- package/dist/actions/documents/validate.js.map +1 -0
- package/dist/actions/documents/validateDocuments.worker.js +251 -0
- package/dist/actions/documents/validateDocuments.worker.js.map +1 -0
- package/dist/actions/documents/validation/reporters/index.js +10 -0
- package/dist/actions/documents/validation/reporters/index.js.map +1 -0
- package/dist/actions/documents/validation/reporters/jsonReporter.js +25 -0
- package/dist/actions/documents/validation/reporters/jsonReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/ndjsonReporter.js +18 -0
- package/dist/actions/documents/validation/reporters/ndjsonReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/formatDocumentValidation.js +62 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/formatDocumentValidation.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/index.js +3 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/index.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/prettyReporter.js +92 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/prettyReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/util.js +45 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/util.js.map +1 -0
- package/dist/actions/exec/configClient.worker.js +9 -0
- package/dist/actions/exec/configClient.worker.js.map +1 -0
- package/dist/actions/exec/execScript.js +77 -0
- package/dist/actions/exec/execScript.js.map +1 -0
- package/dist/actions/exec/registerBrowserEnv.worker.js +17 -0
- package/dist/actions/exec/registerBrowserEnv.worker.js.map +1 -0
- package/dist/actions/graphql/SchemaError.js +37 -0
- package/dist/actions/graphql/SchemaError.js.map +1 -0
- package/dist/actions/graphql/extractFromSanitySchema.js +659 -0
- package/dist/actions/graphql/extractFromSanitySchema.js.map +1 -0
- package/dist/actions/graphql/gen1/generateTypeFilters.js +226 -0
- package/dist/actions/graphql/gen1/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen1/generateTypeQueries.js +85 -0
- package/dist/actions/graphql/gen1/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen1/index.js +19 -0
- package/dist/actions/graphql/gen1/index.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/booleanFilters.js +26 -0
- package/dist/actions/graphql/gen2/filters/booleanFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/dateFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/dateFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/dateTimeFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/dateTimeFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/documentFilters.js +21 -0
- package/dist/actions/graphql/gen2/filters/documentFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/floatFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/floatFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/idFilters.js +44 -0
- package/dist/actions/graphql/gen2/filters/idFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/integerFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/integerFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/stringFilters.js +49 -0
- package/dist/actions/graphql/gen2/filters/stringFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeFilters.js +85 -0
- package/dist/actions/graphql/gen2/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeQueries.js +107 -0
- package/dist/actions/graphql/gen2/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeSortings.js +70 -0
- package/dist/actions/graphql/gen2/generateTypeSortings.js.map +1 -0
- package/dist/actions/graphql/gen2/index.js +22 -0
- package/dist/actions/graphql/gen2/index.js.map +1 -0
- package/dist/actions/graphql/gen3/filters/documentFilters.js +21 -0
- package/dist/actions/graphql/gen3/filters/documentFilters.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeFilters.js +101 -0
- package/dist/actions/graphql/gen3/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeQueries.js +104 -0
- package/dist/actions/graphql/gen3/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeSortings.js +70 -0
- package/dist/actions/graphql/gen3/generateTypeSortings.js.map +1 -0
- package/dist/actions/graphql/gen3/index.js +31 -0
- package/dist/actions/graphql/gen3/index.js.map +1 -0
- package/dist/actions/graphql/gen3/utils.js +12 -0
- package/dist/actions/graphql/gen3/utils.js.map +1 -0
- package/dist/actions/graphql/getGraphQLAPIs.js +65 -0
- package/dist/actions/graphql/getGraphQLAPIs.js.map +1 -0
- package/dist/actions/graphql/getGraphQLAPIs.worker.js +126 -0
- package/dist/actions/graphql/getGraphQLAPIs.worker.js.map +1 -0
- package/dist/actions/graphql/graphqlDebug.js +4 -0
- package/dist/actions/graphql/graphqlDebug.js.map +1 -0
- package/dist/actions/graphql/helpUrls.js +3 -0
- package/dist/actions/graphql/helpUrls.js.map +1 -0
- package/dist/actions/graphql/helpers.js +11 -0
- package/dist/actions/graphql/helpers.js.map +1 -0
- package/dist/actions/graphql/resolveApiGeneration.js +43 -0
- package/dist/actions/graphql/resolveApiGeneration.js.map +1 -0
- package/dist/actions/graphql/types.js +3 -0
- package/dist/actions/graphql/types.js.map +1 -0
- package/dist/actions/hook/constants.js +3 -0
- package/dist/actions/hook/constants.js.map +1 -0
- package/dist/actions/hook/formatFailure.js +29 -0
- package/dist/actions/hook/formatFailure.js.map +1 -0
- package/dist/actions/hook/types.js +3 -0
- package/dist/actions/hook/types.js.map +1 -0
- package/dist/actions/init/bootstrapLocalTemplate.js +137 -0
- package/dist/actions/init/bootstrapLocalTemplate.js.map +1 -0
- package/dist/actions/init/bootstrapRemoteTemplate.js +109 -0
- package/dist/actions/init/bootstrapRemoteTemplate.js.map +1 -0
- package/dist/actions/init/bootstrapTemplate.js +32 -0
- package/dist/actions/init/bootstrapTemplate.js.map +1 -0
- package/dist/actions/init/checkNextJsReactCompatibility.js +21 -0
- package/dist/actions/init/checkNextJsReactCompatibility.js.map +1 -0
- package/dist/actions/init/constants.js +3 -0
- package/dist/actions/init/constants.js.map +1 -0
- package/dist/actions/init/countNestedFolders.js +6 -0
- package/dist/actions/init/countNestedFolders.js.map +1 -0
- package/dist/actions/init/createAppCliConfig.js +19 -0
- package/dist/actions/init/createAppCliConfig.js.map +1 -0
- package/dist/actions/init/createCliConfig.js +27 -0
- package/dist/actions/init/createCliConfig.js.map +1 -0
- package/dist/actions/init/createPackageManifest.js +86 -0
- package/dist/actions/init/createPackageManifest.js.map +1 -0
- package/dist/actions/init/createStudioConfig.js +41 -0
- package/dist/actions/init/createStudioConfig.js.map +1 -0
- package/dist/actions/init/determineAppTemplate.js +16 -0
- package/dist/actions/init/determineAppTemplate.js.map +1 -0
- package/dist/actions/init/env/createOrAppendEnvVars.js +25 -0
- package/dist/actions/init/env/createOrAppendEnvVars.js.map +1 -0
- package/dist/actions/init/env/parseAndUpdateEnvVars.js +42 -0
- package/dist/actions/init/env/parseAndUpdateEnvVars.js.map +1 -0
- package/dist/actions/init/env/writeEnvVarsToFile.js +49 -0
- package/dist/actions/init/env/writeEnvVarsToFile.js.map +1 -0
- package/dist/actions/init/fetchPostInitPrompt.js +30 -0
- package/dist/actions/init/fetchPostInitPrompt.js.map +1 -0
- package/dist/actions/init/git.js +65 -0
- package/dist/actions/init/git.js.map +1 -0
- package/dist/actions/init/processTemplate.js +56 -0
- package/dist/actions/init/processTemplate.js.map +1 -0
- package/dist/actions/init/remoteTemplate.js +211 -0
- package/dist/actions/init/remoteTemplate.js.map +1 -0
- package/dist/actions/init/resolvePackageManager.js +20 -0
- package/dist/actions/init/resolvePackageManager.js.map +1 -0
- package/dist/actions/init/templates/appQuickstart.js +28 -0
- package/dist/actions/init/templates/appQuickstart.js.map +1 -0
- package/dist/actions/init/templates/appSanityUi.js +30 -0
- package/dist/actions/init/templates/appSanityUi.js.map +1 -0
- package/dist/actions/init/templates/blog.js +4 -0
- package/dist/actions/init/templates/blog.js.map +1 -0
- package/dist/actions/init/templates/clean.js +4 -0
- package/dist/actions/init/templates/clean.js.map +1 -0
- package/dist/actions/init/templates/getStarted.js +35 -0
- package/dist/actions/init/templates/getStarted.js.map +1 -0
- package/dist/actions/init/templates/index.js +23 -0
- package/dist/actions/init/templates/index.js.map +1 -0
- package/dist/actions/init/templates/moviedb.js +34 -0
- package/dist/actions/init/templates/moviedb.js.map +1 -0
- package/dist/actions/init/templates/nextjs/index.js +213 -0
- package/dist/actions/init/templates/nextjs/index.js.map +1 -0
- package/dist/actions/init/templates/nextjs/schemaTypes/blog.js +247 -0
- package/dist/actions/init/templates/nextjs/schemaTypes/blog.js.map +1 -0
- package/dist/actions/init/templates/quickstart.js +4 -0
- package/dist/actions/init/templates/quickstart.js.map +1 -0
- package/dist/actions/init/templates/shopify.js +77 -0
- package/dist/actions/init/templates/shopify.js.map +1 -0
- package/dist/actions/init/templates/shopifyOnline.js +49 -0
- package/dist/actions/init/templates/shopifyOnline.js.map +1 -0
- package/dist/actions/init/types.js +3 -0
- package/dist/actions/init/types.js.map +1 -0
- package/dist/actions/init/updateInitialTemplateMetadata.js +17 -0
- package/dist/actions/init/updateInitialTemplateMetadata.js.map +1 -0
- package/dist/actions/manifest/SchemaIcon.js +21 -0
- package/dist/actions/manifest/SchemaIcon.js.map +1 -0
- package/dist/actions/manifest/extractAppManifest.js +51 -0
- package/dist/actions/manifest/extractAppManifest.js.map +1 -0
- package/dist/actions/manifest/extractManifest.js +93 -0
- package/dist/actions/manifest/extractManifest.js.map +1 -0
- package/dist/actions/manifest/extractWorkspaceManifest.js +406 -0
- package/dist/actions/manifest/extractWorkspaceManifest.js.map +1 -0
- package/dist/actions/manifest/purifyConfig.js +307 -0
- package/dist/actions/manifest/purifyConfig.js.map +1 -0
- package/dist/actions/manifest/schemaTypeHelpers.js +110 -0
- package/dist/actions/manifest/schemaTypeHelpers.js.map +1 -0
- package/dist/actions/manifest/types.js +5 -0
- package/dist/actions/manifest/types.js.map +1 -0
- package/dist/actions/mcp/detectAvailableEditors.js +75 -0
- package/dist/actions/mcp/detectAvailableEditors.js.map +1 -0
- package/dist/actions/mcp/editorConfigs.js +147 -0
- package/dist/actions/mcp/editorConfigs.js.map +1 -0
- package/dist/actions/mcp/promptForMCPSetup.js +24 -0
- package/dist/actions/mcp/promptForMCPSetup.js.map +1 -0
- package/dist/actions/mcp/setupMCP.js +88 -0
- package/dist/actions/mcp/setupMCP.js.map +1 -0
- package/dist/actions/mcp/types.js +3 -0
- package/dist/actions/mcp/types.js.map +1 -0
- package/dist/actions/mcp/writeMCPConfig.js +41 -0
- package/dist/actions/mcp/writeMCPConfig.js.map +1 -0
- package/dist/actions/media/__tests__/createMockClient.js +32 -0
- package/dist/actions/media/__tests__/createMockClient.js.map +1 -0
- package/dist/actions/media/getMediaLibraryConfig.js +5 -0
- package/dist/actions/media/getMediaLibraryConfig.js.map +1 -0
- package/dist/actions/media/importAspects.js +112 -0
- package/dist/actions/media/importAspects.js.map +1 -0
- package/dist/actions/media/importMedia.js +213 -0
- package/dist/actions/media/importMedia.js.map +1 -0
- package/dist/actions/media/importMediaDebug.js +4 -0
- package/dist/actions/media/importMediaDebug.js.map +1 -0
- package/dist/actions/organizations/getOrganization.js +67 -0
- package/dist/actions/organizations/getOrganization.js.map +1 -0
- package/dist/actions/organizations/getOrganizationChoices.js +23 -0
- package/dist/actions/organizations/getOrganizationChoices.js.map +1 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js +9 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js.map +1 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js +24 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js.map +1 -0
- package/dist/actions/organizations/validateOrganizationName.js +10 -0
- package/dist/actions/organizations/validateOrganizationName.js.map +1 -0
- package/dist/actions/preview/getPreviewServerConfig.js +16 -0
- package/dist/actions/preview/getPreviewServerConfig.js.map +1 -0
- package/dist/actions/preview/previewAction.js +20 -0
- package/dist/actions/preview/previewAction.js.map +1 -0
- package/dist/actions/preview/types.js +3 -0
- package/dist/actions/preview/types.js.map +1 -0
- package/dist/actions/projects/getManageUrl.js +7 -0
- package/dist/actions/projects/getManageUrl.js.map +1 -0
- package/dist/actions/projects/validateProjectName.js +11 -0
- package/dist/actions/projects/validateProjectName.js.map +1 -0
- package/dist/actions/schema/deleteSchemaAction.js +101 -0
- package/dist/actions/schema/deleteSchemaAction.js.map +1 -0
- package/dist/actions/schema/deploySchemas.js +98 -0
- package/dist/actions/schema/deploySchemas.js.map +1 -0
- package/dist/actions/schema/extractSanitySchema.worker.js +38 -0
- package/dist/actions/schema/extractSanitySchema.worker.js.map +1 -0
- package/dist/actions/schema/extractSchema.js +77 -0
- package/dist/actions/schema/extractSchema.js.map +1 -0
- package/dist/actions/schema/formatSchemaValidation.js +74 -0
- package/dist/actions/schema/formatSchemaValidation.js.map +1 -0
- package/dist/actions/schema/listSchemas.js +119 -0
- package/dist/actions/schema/listSchemas.js.map +1 -0
- package/dist/actions/schema/metafile.js +51 -0
- package/dist/actions/schema/metafile.js.map +1 -0
- package/dist/actions/schema/schemaStoreTypes.js +19 -0
- package/dist/actions/schema/schemaStoreTypes.js.map +1 -0
- package/dist/actions/schema/types.js +9 -0
- package/dist/actions/schema/types.js.map +1 -0
- package/dist/actions/schema/utils/debug.js +6 -0
- package/dist/actions/schema/utils/debug.js.map +1 -0
- package/dist/actions/schema/utils/extractValidationFromSchemaError.js +12 -0
- package/dist/actions/schema/utils/extractValidationFromSchemaError.js.map +1 -0
- package/dist/actions/schema/utils/manifestExtractor.js +33 -0
- package/dist/actions/schema/utils/manifestExtractor.js.map +1 -0
- package/dist/actions/schema/utils/manifestReader.js +71 -0
- package/dist/actions/schema/utils/manifestReader.js.map +1 -0
- package/dist/actions/schema/utils/schemaStoreOutStrings.js +11 -0
- package/dist/actions/schema/utils/schemaStoreOutStrings.js.map +1 -0
- package/dist/actions/schema/utils/schemaStoreValidation.js +108 -0
- package/dist/actions/schema/utils/schemaStoreValidation.js.map +1 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js +9 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js.map +1 -0
- package/dist/actions/schema/utils/workspaceSchemaId.js +23 -0
- package/dist/actions/schema/utils/workspaceSchemaId.js.map +1 -0
- package/dist/actions/schema/validateAction.js +71 -0
- package/dist/actions/schema/validateAction.js.map +1 -0
- package/dist/actions/schema/validateSchema.worker.js +124 -0
- package/dist/actions/schema/validateSchema.worker.js.map +1 -0
- package/dist/actions/telemetry/getLearnMoreMessage.js +15 -0
- package/dist/actions/telemetry/getLearnMoreMessage.js.map +1 -0
- package/dist/actions/telemetry/getStatusDisplay.js +26 -0
- package/dist/actions/telemetry/getStatusDisplay.js.map +1 -0
- package/dist/actions/telemetry/getStatusMessage.js +36 -0
- package/dist/actions/telemetry/getStatusMessage.js.map +1 -0
- package/dist/actions/telemetry/resolveConsent.js +48 -0
- package/dist/actions/telemetry/resolveConsent.js.map +1 -0
- package/dist/actions/telemetry/setConsent.js +83 -0
- package/dist/actions/telemetry/setConsent.js.map +1 -0
- package/dist/actions/telemetry/telemetryDebug.js +4 -0
- package/dist/actions/telemetry/telemetryDebug.js.map +1 -0
- package/dist/actions/telemetry/telemetryDisclosure.js +33 -0
- package/dist/actions/telemetry/telemetryDisclosure.js.map +1 -0
- package/dist/actions/telemetry/telemetryLearnMoreMessage.js +15 -0
- package/dist/actions/telemetry/telemetryLearnMoreMessage.js.map +1 -0
- package/dist/actions/tokens/constants.js +5 -0
- package/dist/actions/tokens/constants.js.map +1 -0
- package/dist/actions/tokens/types.js +3 -0
- package/dist/actions/tokens/types.js.map +1 -0
- package/dist/actions/tokens/validateRole.js +23 -0
- package/dist/actions/tokens/validateRole.js.map +1 -0
- package/dist/actions/undeploy/getStudioOrAppUserApplication.js +36 -0
- package/dist/actions/undeploy/getStudioOrAppUserApplication.js.map +1 -0
- package/dist/actions/users/getMembersForProject.js +47 -0
- package/dist/actions/users/getMembersForProject.js.map +1 -0
- package/dist/actions/users/getPendingInvitations.js +15 -0
- package/dist/actions/users/getPendingInvitations.js.map +1 -0
- package/dist/actions/users/types.js +3 -0
- package/dist/actions/users/types.js.map +1 -0
- package/dist/actions/users/usersDebug.js +4 -0
- package/dist/actions/users/usersDebug.js.map +1 -0
- package/dist/actions/users/validateEmail.js +14 -0
- package/dist/actions/users/validateEmail.js.map +1 -0
- package/dist/actions/versions/buildPackageArray.js +44 -0
- package/dist/actions/versions/buildPackageArray.js.map +1 -0
- package/dist/actions/versions/filterSanityModules.js +20 -0
- package/dist/actions/versions/filterSanityModules.js.map +1 -0
- package/dist/actions/versions/findSanityModulesVersions.js +47 -0
- package/dist/actions/versions/findSanityModulesVersions.js.map +1 -0
- package/dist/actions/versions/getFormatters.js +30 -0
- package/dist/actions/versions/getFormatters.js.map +1 -0
- package/dist/actions/versions/tryFindLatestVersion.js +21 -0
- package/dist/actions/versions/tryFindLatestVersion.js.map +1 -0
- package/dist/actions/versions/types.js +5 -0
- package/dist/actions/versions/types.js.map +1 -0
- package/dist/actions/versions/versionsDebug.js +4 -0
- package/dist/actions/versions/versionsDebug.js.map +1 -0
- package/dist/commands/backup/disable.js +94 -0
- package/dist/commands/backup/disable.js.map +1 -0
- package/dist/commands/backup/download.js +291 -0
- package/dist/commands/backup/download.js.map +1 -0
- package/dist/commands/backup/enable.js +99 -0
- package/dist/commands/backup/enable.js.map +1 -0
- package/dist/commands/backup/list.js +187 -0
- package/dist/commands/backup/list.js.map +1 -0
- package/dist/commands/build.js +82 -0
- package/dist/commands/build.js.map +1 -0
- package/dist/commands/codemod.js +141 -0
- package/dist/commands/codemod.js.map +1 -0
- package/dist/commands/cors/add.js +154 -0
- package/dist/commands/cors/add.js.map +1 -0
- package/dist/commands/cors/delete.js +90 -0
- package/dist/commands/cors/delete.js.map +1 -0
- package/dist/commands/cors/list.js +40 -0
- package/dist/commands/cors/list.js.map +1 -0
- package/dist/commands/dataset/alias/create.js +118 -0
- package/dist/commands/dataset/alias/create.js.map +1 -0
- package/dist/commands/dataset/alias/delete.js +88 -0
- package/dist/commands/dataset/alias/delete.js.map +1 -0
- package/dist/commands/dataset/alias/link.js +137 -0
- package/dist/commands/dataset/alias/link.js.map +1 -0
- package/dist/commands/dataset/alias/unlink.js +98 -0
- package/dist/commands/dataset/alias/unlink.js.map +1 -0
- package/dist/commands/dataset/copy.js +369 -0
- package/dist/commands/dataset/copy.js.map +1 -0
- package/dist/commands/dataset/create.js +106 -0
- package/dist/commands/dataset/create.js.map +1 -0
- package/dist/commands/dataset/delete.js +104 -0
- package/dist/commands/dataset/delete.js.map +1 -0
- package/dist/commands/dataset/export.js +271 -0
- package/dist/commands/dataset/export.js.map +1 -0
- package/dist/commands/dataset/import.js +3 -0
- package/dist/commands/dataset/import.js.map +1 -0
- package/dist/commands/dataset/list.js +50 -0
- package/dist/commands/dataset/list.js.map +1 -0
- package/dist/commands/dataset/visibility/get.js +55 -0
- package/dist/commands/dataset/visibility/get.js.map +1 -0
- package/dist/commands/dataset/visibility/set.js +88 -0
- package/dist/commands/dataset/visibility/set.js.map +1 -0
- package/dist/commands/debug.js +93 -0
- package/dist/commands/debug.js.map +1 -0
- package/dist/commands/deploy.js +115 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/dev.js +65 -0
- package/dist/commands/dev.js.map +1 -0
- package/dist/commands/docs/browse.js +15 -0
- package/dist/commands/docs/browse.js.map +1 -0
- package/dist/commands/docs/read.js +81 -0
- package/dist/commands/docs/read.js.map +1 -0
- package/dist/commands/docs/search.js +111 -0
- package/dist/commands/docs/search.js.map +1 -0
- package/dist/commands/documents/create.js +338 -0
- package/dist/commands/documents/create.js.map +1 -0
- package/dist/commands/documents/delete.js +104 -0
- package/dist/commands/documents/delete.js.map +1 -0
- package/dist/commands/documents/get.js +85 -0
- package/dist/commands/documents/get.js.map +1 -0
- package/dist/commands/documents/query.js +105 -0
- package/dist/commands/documents/query.js.map +1 -0
- package/dist/commands/documents/validate.js +142 -0
- package/dist/commands/documents/validate.js.map +1 -0
- package/dist/commands/exec.js +54 -0
- package/dist/commands/exec.js.map +1 -0
- package/dist/commands/graphql/deploy.js +429 -0
- package/dist/commands/graphql/deploy.js.map +1 -0
- package/dist/commands/graphql/list.js +53 -0
- package/dist/commands/graphql/list.js.map +1 -0
- package/dist/commands/graphql/undeploy.js +143 -0
- package/dist/commands/graphql/undeploy.js.map +1 -0
- package/dist/commands/hook/attempt.js +66 -0
- package/dist/commands/hook/attempt.js.map +1 -0
- package/dist/commands/hook/create.js +46 -0
- package/dist/commands/hook/create.js.map +1 -0
- package/dist/commands/hook/delete.js +86 -0
- package/dist/commands/hook/delete.js.map +1 -0
- package/dist/commands/hook/list.js +46 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/hook/logs.js +184 -0
- package/dist/commands/hook/logs.js.map +1 -0
- package/dist/commands/init.js +1389 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/install.js +43 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/learn.js +15 -0
- package/dist/commands/learn.js.map +1 -0
- package/dist/commands/login.js +50 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.js +37 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/manage.js +29 -0
- package/dist/commands/manage.js.map +1 -0
- package/dist/commands/manifest/extract.js +43 -0
- package/dist/commands/manifest/extract.js.map +1 -0
- package/dist/commands/mcp/configure.js +28 -0
- package/dist/commands/mcp/configure.js.map +1 -0
- package/dist/commands/media/create-aspect.js +88 -0
- package/dist/commands/media/create-aspect.js.map +1 -0
- package/dist/commands/media/delete-aspect.js +85 -0
- package/dist/commands/media/delete-aspect.js.map +1 -0
- package/dist/commands/media/deploy-aspect.js +151 -0
- package/dist/commands/media/deploy-aspect.js.map +1 -0
- package/dist/commands/media/export.js +210 -0
- package/dist/commands/media/export.js.map +1 -0
- package/dist/commands/media/import.js +160 -0
- package/dist/commands/media/import.js.map +1 -0
- package/dist/commands/openapi/get.js +83 -0
- package/dist/commands/openapi/get.js.map +1 -0
- package/dist/commands/openapi/list.js +80 -0
- package/dist/commands/openapi/list.js.map +1 -0
- package/dist/commands/preview.js +60 -0
- package/dist/commands/preview.js.map +1 -0
- package/dist/commands/projects/create.js +181 -0
- package/dist/commands/projects/create.js.map +1 -0
- package/dist/commands/projects/list.js +76 -0
- package/dist/commands/projects/list.js.map +1 -0
- package/dist/commands/schema/delete.js +91 -0
- package/dist/commands/schema/delete.js.map +1 -0
- package/dist/commands/schema/deploy.js +98 -0
- package/dist/commands/schema/deploy.js.map +1 -0
- package/dist/commands/schema/extract.js +46 -0
- package/dist/commands/schema/extract.js.map +1 -0
- package/dist/commands/schema/list.js +104 -0
- package/dist/commands/schema/list.js.map +1 -0
- package/dist/commands/schema/validate.js +73 -0
- package/dist/commands/schema/validate.js.map +1 -0
- package/dist/commands/telemetry/disable.js +33 -0
- package/dist/commands/telemetry/disable.js.map +1 -0
- package/dist/commands/telemetry/enable.js +33 -0
- package/dist/commands/telemetry/enable.js.map +1 -0
- package/dist/commands/telemetry/status.js +25 -0
- package/dist/commands/telemetry/status.js.map +1 -0
- package/dist/commands/tokens/add.js +135 -0
- package/dist/commands/tokens/add.js.map +1 -0
- package/dist/commands/tokens/delete.js +107 -0
- package/dist/commands/tokens/delete.js.map +1 -0
- package/dist/commands/tokens/list.js +92 -0
- package/dist/commands/tokens/list.js.map +1 -0
- package/dist/commands/undeploy.js +93 -0
- package/dist/commands/undeploy.js.map +1 -0
- package/dist/commands/users/invite.js +100 -0
- package/dist/commands/users/invite.js.map +1 -0
- package/dist/commands/users/list.js +101 -0
- package/dist/commands/users/list.js.map +1 -0
- package/dist/commands/versions.js +27 -0
- package/dist/commands/versions.js.map +1 -0
- package/dist/config/createCliConfig.js +9 -0
- package/dist/config/createCliConfig.js.map +1 -0
- package/dist/config/defineCliConfig.js +5 -0
- package/dist/config/defineCliConfig.js.map +1 -0
- package/dist/hooks/prerun/flushTelemetry.worker.js +22 -0
- package/dist/hooks/prerun/flushTelemetry.worker.js.map +1 -0
- package/dist/hooks/prerun/injectEnvVariables.js +31 -0
- package/dist/hooks/prerun/injectEnvVariables.js.map +1 -0
- package/dist/hooks/prerun/setupTelemetry.js +72 -0
- package/dist/hooks/prerun/setupTelemetry.js.map +1 -0
- package/dist/hooks/prerun/warnings.js +6 -0
- package/dist/hooks/prerun/warnings.js.map +1 -0
- package/dist/index.d.ts +2326 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/init/nextjs.js +56 -0
- package/dist/prompts/init/nextjs.js.map +1 -0
- package/dist/prompts/init/promptForTypescript.js +9 -0
- package/dist/prompts/init/promptForTypescript.js.map +1 -0
- package/dist/prompts/promptForDataset.js +32 -0
- package/dist/prompts/promptForDataset.js.map +1 -0
- package/dist/prompts/promptForDatasetAclMode.js +27 -0
- package/dist/prompts/promptForDatasetAclMode.js.map +1 -0
- package/dist/prompts/promptForDatasetAliasName.js +17 -0
- package/dist/prompts/promptForDatasetAliasName.js.map +1 -0
- package/dist/prompts/promptForDatasetName.js +20 -0
- package/dist/prompts/promptForDatasetName.js.map +1 -0
- package/dist/prompts/promptForDefaultConfig.js +12 -0
- package/dist/prompts/promptForDefaultConfig.js.map +1 -0
- package/dist/prompts/promptForMediaLibrary.js +37 -0
- package/dist/prompts/promptForMediaLibrary.js.map +1 -0
- package/dist/prompts/promptForOrganizationName.js +11 -0
- package/dist/prompts/promptForOrganizationName.js.map +1 -0
- package/dist/prompts/promptForProjectName.js +11 -0
- package/dist/prompts/promptForProjectName.js.map +1 -0
- package/dist/prompts/selectDataset.js +12 -0
- package/dist/prompts/selectDataset.js.map +1 -0
- package/dist/prompts/selectMediaLibrary.js +34 -0
- package/dist/prompts/selectMediaLibrary.js.map +1 -0
- package/dist/server/devServer.js +53 -0
- package/dist/server/devServer.js.map +1 -0
- package/dist/server/gracefulServerDeath.js +12 -0
- package/dist/server/gracefulServerDeath.js.map +1 -0
- package/dist/server/previewServer.js +93 -0
- package/dist/server/previewServer.js.map +1 -0
- package/dist/server/serverDebug.js +4 -0
- package/dist/server/serverDebug.js.map +1 -0
- package/dist/server/vite/plugin-sanity-basepath-redirect.js +25 -0
- package/dist/server/vite/plugin-sanity-basepath-redirect.js.map +1 -0
- package/dist/server/vite/plugin-sanity-build-entries.js +65 -0
- package/dist/server/vite/plugin-sanity-build-entries.js.map +1 -0
- package/dist/server/vite/plugin-sanity-favicons.js +72 -0
- package/dist/server/vite/plugin-sanity-favicons.js.map +1 -0
- package/dist/server/vite/plugin-sanity-runtime-rewrite.js +18 -0
- package/dist/server/vite/plugin-sanity-runtime-rewrite.js.map +1 -0
- package/dist/services/auth.js +13 -0
- package/dist/services/auth.js.map +1 -0
- package/dist/services/backup.js +51 -0
- package/dist/services/backup.js.map +1 -0
- package/dist/services/cors.js +38 -0
- package/dist/services/cors.js.map +1 -0
- package/dist/services/datasetAliases.js +64 -0
- package/dist/services/datasetAliases.js.map +1 -0
- package/dist/services/datasets.js +153 -0
- package/dist/services/datasets.js.map +1 -0
- package/dist/services/docs.js +46 -0
- package/dist/services/docs.js.map +1 -0
- package/dist/services/documents.js +56 -0
- package/dist/services/documents.js.map +1 -0
- package/dist/services/getProjectFeatures.js +16 -0
- package/dist/services/getProjectFeatures.js.map +1 -0
- package/dist/services/getUrlHeaders.js +36 -0
- package/dist/services/getUrlHeaders.js.map +1 -0
- package/dist/services/graphql.js +96 -0
- package/dist/services/graphql.js.map +1 -0
- package/dist/services/hooks.js +59 -0
- package/dist/services/hooks.js.map +1 -0
- package/dist/services/mcp.js +50 -0
- package/dist/services/mcp.js.map +1 -0
- package/dist/services/mediaLibraries.js +74 -0
- package/dist/services/mediaLibraries.js.map +1 -0
- package/dist/services/organizations.js +42 -0
- package/dist/services/organizations.js.map +1 -0
- package/dist/services/plans.js +37 -0
- package/dist/services/plans.js.map +1 -0
- package/dist/services/projects.js +119 -0
- package/dist/services/projects.js.map +1 -0
- package/dist/services/schemas.js +40 -0
- package/dist/services/schemas.js.map +1 -0
- package/dist/services/telemetry.js +80 -0
- package/dist/services/telemetry.js.map +1 -0
- package/dist/services/tokens.js +72 -0
- package/dist/services/tokens.js.map +1 -0
- package/dist/services/user.js +35 -0
- package/dist/services/user.js.map +1 -0
- package/dist/services/userApplications.js +164 -0
- package/dist/services/userApplications.js.map +1 -0
- package/dist/studioDependencies.js +24 -0
- package/dist/studioDependencies.js.map +1 -0
- package/dist/telemetry/build.telemetry.js +13 -0
- package/dist/telemetry/build.telemetry.js.map +1 -0
- package/dist/telemetry/cli.telemetry.js +8 -0
- package/dist/telemetry/cli.telemetry.js.map +1 -0
- package/dist/telemetry/extractSchema.telemetry.js +8 -0
- package/dist/telemetry/extractSchema.telemetry.js.map +1 -0
- package/dist/telemetry/init.telemetry.js +8 -0
- package/dist/telemetry/init.telemetry.js.map +1 -0
- package/dist/telemetry/login.telemetry.js +8 -0
- package/dist/telemetry/login.telemetry.js.map +1 -0
- package/dist/telemetry/mcp.telemetry.js +8 -0
- package/dist/telemetry/mcp.telemetry.js.map +1 -0
- package/dist/types.js +5 -0
- package/dist/types.js.map +1 -0
- package/dist/typings/deepSortObject.d.js +2 -0
- package/dist/typings/deepSortObject.d.js.map +1 -0
- package/dist/util/absolutify.js +26 -0
- package/dist/util/absolutify.js.map +1 -0
- package/dist/util/appId.js +58 -0
- package/dist/util/appId.js.map +1 -0
- package/dist/util/canLaunchBrowser.js +14 -0
- package/dist/util/canLaunchBrowser.js.map +1 -0
- package/dist/util/cliClient.js +41 -0
- package/dist/util/cliClient.js.map +1 -0
- package/dist/util/compareDependencyVersions.js +73 -0
- package/dist/util/compareDependencyVersions.js.map +1 -0
- package/dist/util/copy.js +37 -0
- package/dist/util/copy.js.map +1 -0
- package/dist/util/copyDir.js +63 -0
- package/dist/util/copyDir.js.map +1 -0
- package/dist/util/detectRuntime.js +20 -0
- package/dist/util/detectRuntime.js.map +1 -0
- package/dist/util/determineIsApp.js +9 -0
- package/dist/util/determineIsApp.js.map +1 -0
- package/dist/util/dirIsEmptyOrNonExistent.js +18 -0
- package/dist/util/dirIsEmptyOrNonExistent.js.map +1 -0
- package/dist/util/ensureTrailingSlash.js +12 -0
- package/dist/util/ensureTrailingSlash.js.map +1 -0
- package/dist/util/errorMessages.js +6 -0
- package/dist/util/errorMessages.js.map +1 -0
- package/dist/util/extractDocumentsFromNdjsonOrTarball.js +88 -0
- package/dist/util/extractDocumentsFromNdjsonOrTarball.js.map +1 -0
- package/dist/util/findNdjsonEntry.js +21 -0
- package/dist/util/findNdjsonEntry.js.map +1 -0
- package/dist/util/formatSize.js +10 -0
- package/dist/util/formatSize.js.map +1 -0
- package/dist/util/frameworkPort.js +61 -0
- package/dist/util/frameworkPort.js.map +1 -0
- package/dist/util/fsUtils.js +34 -0
- package/dist/util/fsUtils.js.map +1 -0
- package/dist/util/getCliVersion.js +28 -0
- package/dist/util/getCliVersion.js.map +1 -0
- package/dist/util/getErrorMessage.js +19 -0
- package/dist/util/getErrorMessage.js.map +1 -0
- package/dist/util/getLocalPackageVersion.js +32 -0
- package/dist/util/getLocalPackageVersion.js.map +1 -0
- package/dist/util/getProjectDefaults.js +77 -0
- package/dist/util/getProjectDefaults.js.map +1 -0
- package/dist/util/getSanityEnv.js +3 -0
- package/dist/util/getSanityEnv.js.map +1 -0
- package/dist/util/getSharedServerConfig.js +31 -0
- package/dist/util/getSharedServerConfig.js.map +1 -0
- package/dist/util/getWorkspace.js +18 -0
- package/dist/util/getWorkspace.js.map +1 -0
- package/dist/util/humanFileSize.js +12 -0
- package/dist/util/humanFileSize.js.map +1 -0
- package/dist/util/importStudioConfig.js +40 -0
- package/dist/util/importStudioConfig.js.map +1 -0
- package/dist/util/isPathDirName.js +6 -0
- package/dist/util/isPathDirName.js.map +1 -0
- package/dist/util/isSanityDocumentish.js +20 -0
- package/dist/util/isSanityDocumentish.js.map +1 -0
- package/dist/util/loadEnv.js +3 -0
- package/dist/util/loadEnv.js.map +1 -0
- package/dist/util/moduleFormatUtils.js +18 -0
- package/dist/util/moduleFormatUtils.js.map +1 -0
- package/dist/util/packageManager/installPackages.js +87 -0
- package/dist/util/packageManager/installPackages.js.map +1 -0
- package/dist/util/packageManager/packageManagerChoice.js +181 -0
- package/dist/util/packageManager/packageManagerChoice.js.map +1 -0
- package/dist/util/packageManager/upgradePackages.js +69 -0
- package/dist/util/packageManager/upgradePackages.js.map +1 -0
- package/dist/util/parseArguments.js +42 -0
- package/dist/util/parseArguments.js.map +1 -0
- package/dist/util/pluralize.js +11 -0
- package/dist/util/pluralize.js.map +1 -0
- package/dist/util/readModuleVersion.js +15 -0
- package/dist/util/readModuleVersion.js.map +1 -0
- package/dist/util/readPackageJson.js +44 -0
- package/dist/util/readPackageJson.js.map +1 -0
- package/dist/util/readPackageManifest.js +46 -0
- package/dist/util/readPackageManifest.js.map +1 -0
- package/dist/util/readdirRecursive.js +24 -0
- package/dist/util/readdirRecursive.js.map +1 -0
- package/dist/util/resolveLatestVersions.js +21 -0
- package/dist/util/resolveLatestVersions.js.map +1 -0
- package/dist/util/toInt.js +9 -0
- package/dist/util/toInt.js.map +1 -0
- package/dist/util/trimHashFromVersion.js +8 -0
- package/dist/util/trimHashFromVersion.js.map +1 -0
- package/dist/util/uniqBy.js +14 -0
- package/dist/util/uniqBy.js.map +1 -0
- package/dist/util/validation/validateDocumentsUtils.js +33 -0
- package/dist/util/validation/validateDocumentsUtils.js.map +1 -0
- package/dist/util/warnAboutMissingAppId.js +15 -0
- package/dist/util/warnAboutMissingAppId.js.map +1 -0
- package/dist/util/warnOnNonProductionEnvironment.js +18 -0
- package/dist/util/warnOnNonProductionEnvironment.js.map +1 -0
- package/dist/util/workerChannels.js +172 -0
- package/dist/util/workerChannels.js.map +1 -0
- package/oclif.config.js +21 -0
- package/oclif.manifest.json +4154 -0
- package/package.json +138 -98
- package/templates/app-quickstart/src/App.css +3 -1
- package/templates/app-quickstart/src/App.tsx +1 -1
- package/templates/app-sanity-ui/src/App.tsx +2 -2
- package/templates/app-sanity-ui/src/ExampleComponent.tsx +2 -1
- package/templates/get-started/plugins/sanity-plugin-tutorial/GetStartedTutorial.tsx +3 -3
- package/templates/get-started/plugins/sanity-plugin-tutorial/index.ts +2 -2
- package/templates/shopify/components/hotspots/ProductTooltip.tsx +1 -1
- package/templates/shopify/components/icons/Shopify.tsx +0 -2
- package/templates/shopify/components/inputs/CollectionHidden.tsx +0 -1
- package/templates/shopify/components/media/ColorTheme.tsx +1 -1
- package/templates/shopify/constants.ts +4 -4
- package/templates/shopify/plugins/customDocumentActions/index.ts +2 -2
- package/templates/shopify/plugins/customDocumentActions/shopifyDelete.tsx +1 -1
- package/templates/shopify/schemaTypes/documents/collection.tsx +1 -2
- package/templates/shopify/schemaTypes/documents/page.ts +1 -1
- package/templates/shopify/schemaTypes/documents/product.tsx +1 -1
- package/templates/shopify/schemaTypes/documents/productVariant.tsx +2 -3
- package/templates/shopify/schemaTypes/objects/customProductOption/customProductOptionColorObjectType.tsx +0 -1
- package/templates/shopify/schemaTypes/objects/hotspot/productHotspotsType.tsx +1 -3
- package/templates/shopify/schemaTypes/objects/module/collectionReferenceType.tsx +0 -1
- package/templates/shopify/schemaTypes/objects/shopify/placeholderStringType.ts +2 -3
- package/templates/shopify/schemaTypes/objects/shopify/productWithVariantType.tsx +1 -1
- package/templates/shopify/schemaTypes/objects/shopify/shopifyCollectionType.ts +1 -2
- package/templates/shopify/schemaTypes/objects/shopify/shopifyProductType.ts +1 -2
- package/templates/shopify/schemaTypes/portableText/portableTextType.tsx +7 -7
- package/templates/shopify/schemaTypes/singletons/homeType.ts +8 -8
- package/templates/shopify/structure/collectionStructure.ts +4 -1
- package/templates/shopify/structure/colorThemeStructure.ts +1 -1
- package/templates/shopify/structure/homeStructure.ts +2 -2
- package/templates/shopify/structure/index.ts +1 -1
- package/templates/shopify/structure/pageStructure.ts +2 -2
- package/templates/shopify/structure/productStructure.ts +7 -7
- package/templates/shopify/structure/settingStructure.ts +1 -1
- package/templates/shopify/utils/defineStructure.ts +1 -1
- package/templates/shopify-online-storefront/plugins/shopifyDocumentActions/index.ts +1 -1
- package/templates/shopify-online-storefront/plugins/shopifyDocumentActions/shopifyDelete.tsx +1 -1
- package/templates/shopify-online-storefront/structure/collectionStructure.ts +4 -1
- package/templates/shopify-online-storefront/structure/productStructure.ts +4 -4
- package/templates/shopify-online-storefront/utils/defineStructure.ts +1 -1
- package/bin/dev.js +0 -30
- package/bin/sanity +0 -14
- package/lib/_chunks-cjs/cli.js +0 -70870
- package/lib/_chunks-cjs/cli.js.map +0 -1
- package/lib/_chunks-cjs/cliWorker.js +0 -19
- package/lib/_chunks-cjs/cliWorker.js.map +0 -1
- package/lib/_chunks-cjs/generateAction.js +0 -128
- package/lib/_chunks-cjs/generateAction.js.map +0 -1
- package/lib/_chunks-cjs/getCliConfig.js +0 -89
- package/lib/_chunks-cjs/getCliConfig.js.map +0 -1
- package/lib/_chunks-cjs/index.js +0 -31
- package/lib/_chunks-cjs/index.js.map +0 -1
- package/lib/_chunks-cjs/journeyConfig.js +0 -113
- package/lib/_chunks-cjs/journeyConfig.js.map +0 -1
- package/lib/_chunks-cjs/loadEnv.js +0 -347
- package/lib/_chunks-cjs/loadEnv.js.map +0 -1
- package/lib/_chunks-dts/types.d.ts +0 -432
- package/lib/cli.d.ts +0 -7
- package/lib/cli.js +0 -10
- package/lib/cli.js.map +0 -1
- package/lib/index.d.ts +0 -44
- package/lib/index.js +0 -46
- package/lib/index.js.map +0 -1
- package/lib/run.d.ts +0 -1
- package/lib/run.js +0 -8
- package/lib/run.js.map +0 -1
- package/lib/workers/getAndWriteJourneySchema.d.ts +0 -1
- package/lib/workers/getAndWriteJourneySchema.js +0 -4
- package/lib/workers/getAndWriteJourneySchema.js.map +0 -1
- package/lib/workers/getCliConfig.d.ts +0 -1
- package/lib/workers/getCliConfig.js +0 -10
- package/lib/workers/getCliConfig.js.map +0 -1
- package/lib/workers/typegenGenerate.d.ts +0 -18
- package/lib/workers/typegenGenerate.js +0 -47
- package/lib/workers/typegenGenerate.js.map +0 -1
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { createWriteStream } from 'node:fs';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { pipeline } from 'node:stream/promises';
|
|
4
|
+
import { getIt } from 'get-it';
|
|
5
|
+
import { httpErrors, keepAlive, promise, retry } from 'get-it/middleware';
|
|
6
|
+
import { backupDownloadDebug } from './backupDownloadDebug.js';
|
|
7
|
+
const CONNECTION_TIMEOUT = 15 * 1000 // 15 seconds
|
|
8
|
+
;
|
|
9
|
+
const READ_TIMEOUT = 3 * 60 * 1000 // 3 minutes
|
|
10
|
+
;
|
|
11
|
+
const request = getIt([
|
|
12
|
+
keepAlive(),
|
|
13
|
+
httpErrors(),
|
|
14
|
+
retry(),
|
|
15
|
+
promise()
|
|
16
|
+
]);
|
|
17
|
+
/**
|
|
18
|
+
* Downloads an asset (image or file) from a backup to the specified output directory
|
|
19
|
+
*
|
|
20
|
+
* @param url - The URL to download the asset from
|
|
21
|
+
* @param fileName - The original file name of the asset
|
|
22
|
+
* @param fileType - The type of asset ('image' or 'file')
|
|
23
|
+
* @param outDir - The output directory to save the asset to
|
|
24
|
+
*/ export async function downloadAsset(url, fileName, fileType, outDir) {
|
|
25
|
+
// File names that contain a path to file (e.g. sanity-storage/assets/file-name.tar.gz) fail when archive is
|
|
26
|
+
// created due to missing parent dir (e.g. sanity-storage/assets), so we want to handle them by taking
|
|
27
|
+
// the base name as file name.
|
|
28
|
+
const normalizedFileName = path.basename(fileName);
|
|
29
|
+
const assetFilePath = getAssetFilePath(normalizedFileName, fileType, outDir);
|
|
30
|
+
const response = await request({
|
|
31
|
+
maxRedirects: 5,
|
|
32
|
+
stream: true,
|
|
33
|
+
timeout: {
|
|
34
|
+
connect: CONNECTION_TIMEOUT,
|
|
35
|
+
socket: READ_TIMEOUT
|
|
36
|
+
},
|
|
37
|
+
url
|
|
38
|
+
});
|
|
39
|
+
backupDownloadDebug('Received asset %s with status code %d', normalizedFileName, response?.statusCode);
|
|
40
|
+
await pipeline(response.body, createWriteStream(assetFilePath));
|
|
41
|
+
}
|
|
42
|
+
function getAssetFilePath(fileName, fileType, outDir) {
|
|
43
|
+
// Set assetFilePath if we are downloading an asset file.
|
|
44
|
+
// If it's a JSON document, assetFilePath will be an empty string.
|
|
45
|
+
let assetFilePath = '';
|
|
46
|
+
if (fileType === 'image') {
|
|
47
|
+
assetFilePath = path.join(outDir, 'images', fileName);
|
|
48
|
+
} else if (fileType === 'file') {
|
|
49
|
+
assetFilePath = path.join(outDir, 'files', fileName);
|
|
50
|
+
}
|
|
51
|
+
return assetFilePath;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
//# sourceMappingURL=downloadAsset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/backup/downloadAsset.ts"],"sourcesContent":["import {createWriteStream} from 'node:fs'\nimport path from 'node:path'\nimport {pipeline} from 'node:stream/promises'\n\nimport {getIt} from 'get-it'\nimport {httpErrors, keepAlive, promise, retry} from 'get-it/middleware'\n\nimport {backupDownloadDebug} from './backupDownloadDebug.js'\n\nconst CONNECTION_TIMEOUT = 15 * 1000 // 15 seconds\nconst READ_TIMEOUT = 3 * 60 * 1000 // 3 minutes\n\nconst request = getIt([keepAlive(), httpErrors(), retry(), promise()])\n\n/**\n * Downloads an asset (image or file) from a backup to the specified output directory\n *\n * @param url - The URL to download the asset from\n * @param fileName - The original file name of the asset\n * @param fileType - The type of asset ('image' or 'file')\n * @param outDir - The output directory to save the asset to\n */\nexport async function downloadAsset(\n url: string,\n fileName: string,\n fileType: string,\n outDir: string,\n): Promise<void> {\n // File names that contain a path to file (e.g. sanity-storage/assets/file-name.tar.gz) fail when archive is\n // created due to missing parent dir (e.g. sanity-storage/assets), so we want to handle them by taking\n // the base name as file name.\n const normalizedFileName = path.basename(fileName)\n\n const assetFilePath = getAssetFilePath(normalizedFileName, fileType, outDir)\n\n const response = await request({\n maxRedirects: 5,\n stream: true,\n timeout: {connect: CONNECTION_TIMEOUT, socket: READ_TIMEOUT},\n url,\n })\n\n backupDownloadDebug(\n 'Received asset %s with status code %d',\n normalizedFileName,\n response?.statusCode,\n )\n\n await pipeline(response.body, createWriteStream(assetFilePath))\n}\n\nfunction getAssetFilePath(fileName: string, fileType: string, outDir: string): string {\n // Set assetFilePath if we are downloading an asset file.\n // If it's a JSON document, assetFilePath will be an empty string.\n let assetFilePath = ''\n if (fileType === 'image') {\n assetFilePath = path.join(outDir, 'images', fileName)\n } else if (fileType === 'file') {\n assetFilePath = path.join(outDir, 'files', fileName)\n }\n\n return assetFilePath\n}\n"],"names":["createWriteStream","path","pipeline","getIt","httpErrors","keepAlive","promise","retry","backupDownloadDebug","CONNECTION_TIMEOUT","READ_TIMEOUT","request","downloadAsset","url","fileName","fileType","outDir","normalizedFileName","basename","assetFilePath","getAssetFilePath","response","maxRedirects","stream","timeout","connect","socket","statusCode","body","join"],"mappings":"AAAA,SAAQA,iBAAiB,QAAO,UAAS;AACzC,OAAOC,UAAU,YAAW;AAC5B,SAAQC,QAAQ,QAAO,uBAAsB;AAE7C,SAAQC,KAAK,QAAO,SAAQ;AAC5B,SAAQC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,KAAK,QAAO,oBAAmB;AAEvE,SAAQC,mBAAmB,QAAO,2BAA0B;AAE5D,MAAMC,qBAAqB,KAAK,KAAK,aAAa;;AAClD,MAAMC,eAAe,IAAI,KAAK,KAAK,YAAY;;AAE/C,MAAMC,UAAUR,MAAM;IAACE;IAAaD;IAAcG;IAASD;CAAU;AAErE;;;;;;;CAOC,GACD,OAAO,eAAeM,cACpBC,GAAW,EACXC,QAAgB,EAChBC,QAAgB,EAChBC,MAAc;IAEd,4GAA4G;IAC5G,sGAAsG;IACtG,8BAA8B;IAC9B,MAAMC,qBAAqBhB,KAAKiB,QAAQ,CAACJ;IAEzC,MAAMK,gBAAgBC,iBAAiBH,oBAAoBF,UAAUC;IAErE,MAAMK,WAAW,MAAMV,QAAQ;QAC7BW,cAAc;QACdC,QAAQ;QACRC,SAAS;YAACC,SAAShB;YAAoBiB,QAAQhB;QAAY;QAC3DG;IACF;IAEAL,oBACE,yCACAS,oBACAI,UAAUM;IAGZ,MAAMzB,SAASmB,SAASO,IAAI,EAAE5B,kBAAkBmB;AAClD;AAEA,SAASC,iBAAiBN,QAAgB,EAAEC,QAAgB,EAAEC,MAAc;IAC1E,yDAAyD;IACzD,kEAAkE;IAClE,IAAIG,gBAAgB;IACpB,IAAIJ,aAAa,SAAS;QACxBI,gBAAgBlB,KAAK4B,IAAI,CAACb,QAAQ,UAAUF;IAC9C,OAAO,IAAIC,aAAa,QAAQ;QAC9BI,gBAAgBlB,KAAK4B,IAAI,CAACb,QAAQ,SAASF;IAC7C;IAEA,OAAOK;AACT"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { getIt } from 'get-it';
|
|
2
|
+
import { httpErrors, keepAlive, promise, retry } from 'get-it/middleware';
|
|
3
|
+
import { backupDownloadDebug } from './backupDownloadDebug.js';
|
|
4
|
+
const CONNECTION_TIMEOUT = 15 * 1000 // 15 seconds
|
|
5
|
+
;
|
|
6
|
+
const READ_TIMEOUT = 3 * 60 * 1000 // 3 minutes
|
|
7
|
+
;
|
|
8
|
+
const request = getIt([
|
|
9
|
+
keepAlive(),
|
|
10
|
+
httpErrors(),
|
|
11
|
+
retry(),
|
|
12
|
+
promise()
|
|
13
|
+
]);
|
|
14
|
+
/**
|
|
15
|
+
* Downloads a document from a backup URL
|
|
16
|
+
*
|
|
17
|
+
* @param url - The URL to download the document from
|
|
18
|
+
* @returns The document content as received from the API
|
|
19
|
+
*/ export async function downloadDocument(url) {
|
|
20
|
+
const response = await request({
|
|
21
|
+
maxRedirects: 5,
|
|
22
|
+
timeout: {
|
|
23
|
+
connect: CONNECTION_TIMEOUT,
|
|
24
|
+
socket: READ_TIMEOUT
|
|
25
|
+
},
|
|
26
|
+
url
|
|
27
|
+
});
|
|
28
|
+
backupDownloadDebug('Received document from %s with status code %d', url, response?.statusCode);
|
|
29
|
+
return response.body;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
//# sourceMappingURL=downloadDocument.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/backup/downloadDocument.ts"],"sourcesContent":["import {getIt} from 'get-it'\nimport {httpErrors, keepAlive, promise, retry} from 'get-it/middleware'\n\nimport {backupDownloadDebug} from './backupDownloadDebug.js'\n\nconst CONNECTION_TIMEOUT = 15 * 1000 // 15 seconds\nconst READ_TIMEOUT = 3 * 60 * 1000 // 3 minutes\n\nconst request = getIt([keepAlive(), httpErrors(), retry(), promise()])\n\n/**\n * Downloads a document from a backup URL\n *\n * @param url - The URL to download the document from\n * @returns The document content as received from the API\n */\nexport async function downloadDocument(url: string): Promise<unknown> {\n const response = await request({\n maxRedirects: 5,\n timeout: {connect: CONNECTION_TIMEOUT, socket: READ_TIMEOUT},\n url,\n })\n\n backupDownloadDebug('Received document from %s with status code %d', url, response?.statusCode)\n\n return response.body\n}\n"],"names":["getIt","httpErrors","keepAlive","promise","retry","backupDownloadDebug","CONNECTION_TIMEOUT","READ_TIMEOUT","request","downloadDocument","url","response","maxRedirects","timeout","connect","socket","statusCode","body"],"mappings":"AAAA,SAAQA,KAAK,QAAO,SAAQ;AAC5B,SAAQC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,KAAK,QAAO,oBAAmB;AAEvE,SAAQC,mBAAmB,QAAO,2BAA0B;AAE5D,MAAMC,qBAAqB,KAAK,KAAK,aAAa;;AAClD,MAAMC,eAAe,IAAI,KAAK,KAAK,YAAY;;AAE/C,MAAMC,UAAUR,MAAM;IAACE;IAAaD;IAAcG;IAASD;CAAU;AAErE;;;;;CAKC,GACD,OAAO,eAAeM,iBAAiBC,GAAW;IAChD,MAAMC,WAAW,MAAMH,QAAQ;QAC7BI,cAAc;QACdC,SAAS;YAACC,SAASR;YAAoBS,QAAQR;QAAY;QAC3DG;IACF;IAEAL,oBAAoB,iDAAiDK,KAAKC,UAAUK;IAEpF,OAAOL,SAASM,IAAI;AACtB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Readable } from 'node:stream';
|
|
2
|
+
import { getBackupDetails } from '../../services/backup.js';
|
|
3
|
+
export class PaginatedGetBackupStream extends Readable {
|
|
4
|
+
totalFiles = 0;
|
|
5
|
+
backupId;
|
|
6
|
+
cursor = '';
|
|
7
|
+
datasetName;
|
|
8
|
+
projectId;
|
|
9
|
+
constructor(projectId, datasetName, backupId){
|
|
10
|
+
super({
|
|
11
|
+
objectMode: true
|
|
12
|
+
});
|
|
13
|
+
this.projectId = projectId;
|
|
14
|
+
this.datasetName = datasetName;
|
|
15
|
+
this.backupId = backupId;
|
|
16
|
+
}
|
|
17
|
+
async _read() {
|
|
18
|
+
try {
|
|
19
|
+
const data = await this.fetchNextBackupPage();
|
|
20
|
+
// Set totalFiles when it's fetched for the first time
|
|
21
|
+
if (this.totalFiles === 0) {
|
|
22
|
+
this.totalFiles = data.totalFiles;
|
|
23
|
+
}
|
|
24
|
+
for (const file of data.files){
|
|
25
|
+
this.push(file);
|
|
26
|
+
}
|
|
27
|
+
if (typeof data.nextCursor === 'string' && data.nextCursor !== '') {
|
|
28
|
+
this.cursor = data.nextCursor;
|
|
29
|
+
} else {
|
|
30
|
+
// No more pages left to fetch.
|
|
31
|
+
this.push(null);
|
|
32
|
+
}
|
|
33
|
+
} catch (err) {
|
|
34
|
+
this.destroy(err instanceof Error ? err : new Error(String(err)));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
// fetchNextBackupPage fetches the next page of backed up files from the backup API.
|
|
38
|
+
fetchNextBackupPage() {
|
|
39
|
+
return getBackupDetails({
|
|
40
|
+
backupId: this.backupId,
|
|
41
|
+
datasetName: this.datasetName,
|
|
42
|
+
nextCursor: this.cursor === '' ? undefined : this.cursor,
|
|
43
|
+
projectId: this.projectId
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
//# sourceMappingURL=fetchNextBackupPage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/backup/fetchNextBackupPage.ts"],"sourcesContent":["import {Readable} from 'node:stream'\n\nimport {getBackupDetails} from '../../services/backup.js'\n\nexport interface File {\n name: string\n type: string\n url: string\n}\n\ninterface GetBackupResponse {\n createdAt: string\n files: File[]\n totalFiles: number\n\n nextCursor?: string\n}\n\nexport class PaginatedGetBackupStream extends Readable {\n public totalFiles = 0\n private readonly backupId: string\n private cursor = ''\n private readonly datasetName: string\n private readonly projectId: string\n\n constructor(projectId: string, datasetName: string, backupId: string) {\n super({objectMode: true})\n this.projectId = projectId\n this.datasetName = datasetName\n this.backupId = backupId\n }\n\n async _read(): Promise<void> {\n try {\n const data = await this.fetchNextBackupPage()\n\n // Set totalFiles when it's fetched for the first time\n if (this.totalFiles === 0) {\n this.totalFiles = data.totalFiles\n }\n\n for (const file of data.files) {\n this.push(file)\n }\n\n if (typeof data.nextCursor === 'string' && data.nextCursor !== '') {\n this.cursor = data.nextCursor\n } else {\n // No more pages left to fetch.\n this.push(null)\n }\n } catch (err) {\n this.destroy(err instanceof Error ? err : new Error(String(err)))\n }\n }\n\n // fetchNextBackupPage fetches the next page of backed up files from the backup API.\n fetchNextBackupPage(): Promise<GetBackupResponse> {\n return getBackupDetails({\n backupId: this.backupId,\n datasetName: this.datasetName,\n nextCursor: this.cursor === '' ? undefined : this.cursor,\n projectId: this.projectId,\n })\n }\n}\n"],"names":["Readable","getBackupDetails","PaginatedGetBackupStream","totalFiles","backupId","cursor","datasetName","projectId","objectMode","_read","data","fetchNextBackupPage","file","files","push","nextCursor","err","destroy","Error","String","undefined"],"mappings":"AAAA,SAAQA,QAAQ,QAAO,cAAa;AAEpC,SAAQC,gBAAgB,QAAO,2BAA0B;AAgBzD,OAAO,MAAMC,iCAAiCF;IACrCG,aAAa,EAAC;IACJC,SAAgB;IACzBC,SAAS,GAAE;IACFC,YAAmB;IACnBC,UAAiB;IAElC,YAAYA,SAAiB,EAAED,WAAmB,EAAEF,QAAgB,CAAE;QACpE,KAAK,CAAC;YAACI,YAAY;QAAI;QACvB,IAAI,CAACD,SAAS,GAAGA;QACjB,IAAI,CAACD,WAAW,GAAGA;QACnB,IAAI,CAACF,QAAQ,GAAGA;IAClB;IAEA,MAAMK,QAAuB;QAC3B,IAAI;YACF,MAAMC,OAAO,MAAM,IAAI,CAACC,mBAAmB;YAE3C,sDAAsD;YACtD,IAAI,IAAI,CAACR,UAAU,KAAK,GAAG;gBACzB,IAAI,CAACA,UAAU,GAAGO,KAAKP,UAAU;YACnC;YAEA,KAAK,MAAMS,QAAQF,KAAKG,KAAK,CAAE;gBAC7B,IAAI,CAACC,IAAI,CAACF;YACZ;YAEA,IAAI,OAAOF,KAAKK,UAAU,KAAK,YAAYL,KAAKK,UAAU,KAAK,IAAI;gBACjE,IAAI,CAACV,MAAM,GAAGK,KAAKK,UAAU;YAC/B,OAAO;gBACL,+BAA+B;gBAC/B,IAAI,CAACD,IAAI,CAAC;YACZ;QACF,EAAE,OAAOE,KAAK;YACZ,IAAI,CAACC,OAAO,CAACD,eAAeE,QAAQF,MAAM,IAAIE,MAAMC,OAAOH;QAC7D;IACF;IAEA,oFAAoF;IACpFL,sBAAkD;QAChD,OAAOV,iBAAiB;YACtBG,UAAU,IAAI,CAACA,QAAQ;YACvBE,aAAa,IAAI,CAACA,WAAW;YAC7BS,YAAY,IAAI,CAACV,MAAM,KAAK,KAAKe,YAAY,IAAI,CAACf,MAAM;YACxDE,WAAW,IAAI,CAACA,SAAS;QAC3B;IACF;AACF"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { spinner } from '@sanity/cli-core/ux';
|
|
2
|
+
import prettyMs from 'pretty-ms';
|
|
3
|
+
export const newProgress = (startStep)=>{
|
|
4
|
+
let spin = spinner(startStep).start();
|
|
5
|
+
let lastProgress = {
|
|
6
|
+
step: startStep
|
|
7
|
+
};
|
|
8
|
+
let start = Date.now();
|
|
9
|
+
const print = (progress)=>{
|
|
10
|
+
const elapsed = prettyMs(Date.now() - start);
|
|
11
|
+
spin.text = progress.current && progress.current > 0 && progress.total && progress.total > 0 ? `${progress.step} (${progress.current}/${progress.total}) [${elapsed}]` : `${progress.step} [${elapsed}]`;
|
|
12
|
+
};
|
|
13
|
+
return {
|
|
14
|
+
fail: ()=>{
|
|
15
|
+
spin.fail();
|
|
16
|
+
start = Date.now();
|
|
17
|
+
},
|
|
18
|
+
set: (progress)=>{
|
|
19
|
+
if (progress.step !== lastProgress.step) {
|
|
20
|
+
print(lastProgress); // Print the last progress before moving on
|
|
21
|
+
spin.succeed();
|
|
22
|
+
spin = spinner(progress.step).start();
|
|
23
|
+
start = Date.now();
|
|
24
|
+
} else if (progress.step === lastProgress.step && progress.update) {
|
|
25
|
+
print(progress);
|
|
26
|
+
}
|
|
27
|
+
lastProgress = progress;
|
|
28
|
+
},
|
|
29
|
+
succeed: ()=>{
|
|
30
|
+
spin.succeed();
|
|
31
|
+
start = Date.now();
|
|
32
|
+
},
|
|
33
|
+
update: (progress)=>{
|
|
34
|
+
print(progress);
|
|
35
|
+
lastProgress = progress;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
//# sourceMappingURL=progressSpinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/backup/progressSpinner.ts"],"sourcesContent":["import {spinner} from '@sanity/cli-core/ux'\nimport prettyMs from 'pretty-ms'\n\ninterface ProgressEvent {\n step: string\n\n current?: number\n total?: number\n update?: boolean\n}\n\ninterface ProgressSpinner {\n fail: () => void\n set: (progress: ProgressEvent) => void\n succeed: () => void\n update: (progress: ProgressEvent) => void\n}\n\nexport const newProgress = (startStep: string): ProgressSpinner => {\n let spin = spinner(startStep).start()\n let lastProgress: ProgressEvent = {step: startStep}\n let start = Date.now()\n\n const print = (progress: ProgressEvent) => {\n const elapsed = prettyMs(Date.now() - start)\n spin.text =\n progress.current && progress.current > 0 && progress.total && progress.total > 0\n ? `${progress.step} (${progress.current}/${progress.total}) [${elapsed}]`\n : `${progress.step} [${elapsed}]`\n }\n\n return {\n fail: () => {\n spin.fail()\n start = Date.now()\n },\n set: (progress: ProgressEvent) => {\n if (progress.step !== lastProgress.step) {\n print(lastProgress) // Print the last progress before moving on\n spin.succeed()\n spin = spinner(progress.step).start()\n start = Date.now()\n } else if (progress.step === lastProgress.step && progress.update) {\n print(progress)\n }\n lastProgress = progress\n },\n succeed: () => {\n spin.succeed()\n start = Date.now()\n },\n update: (progress: ProgressEvent) => {\n print(progress)\n lastProgress = progress\n },\n }\n}\n"],"names":["spinner","prettyMs","newProgress","startStep","spin","start","lastProgress","step","Date","now","print","progress","elapsed","text","current","total","fail","set","succeed","update"],"mappings":"AAAA,SAAQA,OAAO,QAAO,sBAAqB;AAC3C,OAAOC,cAAc,YAAW;AAiBhC,OAAO,MAAMC,cAAc,CAACC;IAC1B,IAAIC,OAAOJ,QAAQG,WAAWE,KAAK;IACnC,IAAIC,eAA8B;QAACC,MAAMJ;IAAS;IAClD,IAAIE,QAAQG,KAAKC,GAAG;IAEpB,MAAMC,QAAQ,CAACC;QACb,MAAMC,UAAUX,SAASO,KAAKC,GAAG,KAAKJ;QACtCD,KAAKS,IAAI,GACPF,SAASG,OAAO,IAAIH,SAASG,OAAO,GAAG,KAAKH,SAASI,KAAK,IAAIJ,SAASI,KAAK,GAAG,IAC3E,GAAGJ,SAASJ,IAAI,CAAC,EAAE,EAAEI,SAASG,OAAO,CAAC,CAAC,EAAEH,SAASI,KAAK,CAAC,GAAG,EAAEH,QAAQ,CAAC,CAAC,GACvE,GAAGD,SAASJ,IAAI,CAAC,EAAE,EAAEK,QAAQ,CAAC,CAAC;IACvC;IAEA,OAAO;QACLI,MAAM;YACJZ,KAAKY,IAAI;YACTX,QAAQG,KAAKC,GAAG;QAClB;QACAQ,KAAK,CAACN;YACJ,IAAIA,SAASJ,IAAI,KAAKD,aAAaC,IAAI,EAAE;gBACvCG,MAAMJ,eAAc,2CAA2C;gBAC/DF,KAAKc,OAAO;gBACZd,OAAOJ,QAAQW,SAASJ,IAAI,EAAEF,KAAK;gBACnCA,QAAQG,KAAKC,GAAG;YAClB,OAAO,IAAIE,SAASJ,IAAI,KAAKD,aAAaC,IAAI,IAAII,SAASQ,MAAM,EAAE;gBACjET,MAAMC;YACR;YACAL,eAAeK;QACjB;QACAO,SAAS;YACPd,KAAKc,OAAO;YACZb,QAAQG,KAAKC,GAAG;QAClB;QACAU,QAAQ,CAACR;YACPD,MAAMC;YACNL,eAAeK;QACjB;IACF;AACF,EAAC"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import { rm } from 'node:fs/promises';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { styleText } from 'node:util';
|
|
4
|
+
import { getCliTelemetry, getTimer } from '@sanity/cli-core';
|
|
5
|
+
import { confirm, logSymbols, spinner } from '@sanity/cli-core/ux';
|
|
6
|
+
import semver from 'semver';
|
|
7
|
+
import { AppBuildTrace } from '../../telemetry/build.telemetry.js';
|
|
8
|
+
import { getAppId } from '../../util/appId.js';
|
|
9
|
+
import { compareDependencyVersions } from '../../util/compareDependencyVersions.js';
|
|
10
|
+
import { formatModuleSizes, sortModulesBySize } from '../../util/moduleFormatUtils.js';
|
|
11
|
+
import { readModuleVersion } from '../../util/readModuleVersion.js';
|
|
12
|
+
import { buildDebug } from './buildDebug.js';
|
|
13
|
+
import { buildStaticFiles } from './buildStaticFiles.js';
|
|
14
|
+
import { buildVendorDependencies } from './buildVendorDependencies.js';
|
|
15
|
+
import { determineBasePath } from './determineBasePath.js';
|
|
16
|
+
import { getAppEnvVars } from './getAppEnvVars.js';
|
|
17
|
+
import { getAutoUpdatesImportMap } from './getAutoUpdatesImportMap.js';
|
|
18
|
+
/**
|
|
19
|
+
* Build the Sanity app.
|
|
20
|
+
*
|
|
21
|
+
* @internal
|
|
22
|
+
*/ export async function buildApp(options) {
|
|
23
|
+
const { autoUpdatesEnabled, cliConfig, exit, flags, outDir, output, workDir } = options;
|
|
24
|
+
const unattendedMode = flags.yes;
|
|
25
|
+
const timer = getTimer();
|
|
26
|
+
const defaultOutputDir = path.resolve(path.join(workDir, 'dist'));
|
|
27
|
+
const outputDir = path.resolve(outDir || defaultOutputDir);
|
|
28
|
+
const appId = getAppId(cliConfig);
|
|
29
|
+
const installedSdkVersion = await readModuleVersion(outputDir, '@sanity/sdk-react');
|
|
30
|
+
const installedSanityVersion = await readModuleVersion(outputDir, 'sanity');
|
|
31
|
+
if (!installedSdkVersion) {
|
|
32
|
+
throw new Error(`Failed to find installed @sanity/sdk-react version`);
|
|
33
|
+
}
|
|
34
|
+
let autoUpdatesImports = {};
|
|
35
|
+
if (autoUpdatesEnabled) {
|
|
36
|
+
// Get the clean version without build metadata: https://semver.org/#spec-item-10
|
|
37
|
+
const cleanSDKVersion = semver.parse(installedSdkVersion)?.version;
|
|
38
|
+
if (!cleanSDKVersion) {
|
|
39
|
+
throw new Error(`Failed to parse installed SDK version: ${installedSdkVersion}`);
|
|
40
|
+
}
|
|
41
|
+
// Sanity might not be installed, but if it is, we want to auto update it.
|
|
42
|
+
const cleanSanityVersion = semver.parse(installedSanityVersion)?.version;
|
|
43
|
+
const autoUpdatedPackages = [
|
|
44
|
+
{
|
|
45
|
+
name: '@sanity/sdk',
|
|
46
|
+
version: cleanSDKVersion
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
name: '@sanity/sdk-react',
|
|
50
|
+
version: cleanSDKVersion
|
|
51
|
+
},
|
|
52
|
+
...cleanSanityVersion ? [
|
|
53
|
+
{
|
|
54
|
+
name: 'sanity',
|
|
55
|
+
version: cleanSanityVersion
|
|
56
|
+
}
|
|
57
|
+
] : []
|
|
58
|
+
];
|
|
59
|
+
autoUpdatesImports = getAutoUpdatesImportMap(autoUpdatedPackages, {
|
|
60
|
+
appId
|
|
61
|
+
});
|
|
62
|
+
output.log(`${logSymbols.info} Building with auto-updates enabled`);
|
|
63
|
+
// Check the versions
|
|
64
|
+
const result = await compareDependencyVersions(autoUpdatedPackages, workDir, {
|
|
65
|
+
appId
|
|
66
|
+
});
|
|
67
|
+
// If it is in unattended mode, we don't want to prompt
|
|
68
|
+
if (result?.length && !unattendedMode) {
|
|
69
|
+
const shouldContinue = await confirm({
|
|
70
|
+
default: false,
|
|
71
|
+
message: styleText('yellow', `The following local package versions are different from the versions currently served at runtime.\n` + `When using auto updates, we recommend that you test locally with the same versions before deploying. \n\n` + `${result.map((mod)=>` - ${mod.pkg} (local version: ${mod.installed}, runtime version: ${mod.remote})`).join('\n')} \n\n` + `Continue anyway?`)
|
|
72
|
+
});
|
|
73
|
+
if (!shouldContinue) {
|
|
74
|
+
return exit(1);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
const envVarKeys = getAppEnvVars();
|
|
79
|
+
if (envVarKeys.length > 0) {
|
|
80
|
+
output.log('\nIncluding the following environment variables as part of the JavaScript bundle:');
|
|
81
|
+
for (const key of envVarKeys)output.log(`- ${key}`);
|
|
82
|
+
output.log('');
|
|
83
|
+
}
|
|
84
|
+
let shouldClean = true;
|
|
85
|
+
if (outputDir !== defaultOutputDir && !unattendedMode) {
|
|
86
|
+
shouldClean = await confirm({
|
|
87
|
+
default: true,
|
|
88
|
+
message: `Do you want to delete the existing directory (${outputDir}) first?`
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
// Determine base path for built studio
|
|
92
|
+
const basePath = determineBasePath(cliConfig, 'app');
|
|
93
|
+
let spin;
|
|
94
|
+
if (shouldClean) {
|
|
95
|
+
timer.start('cleanOutputFolder');
|
|
96
|
+
spin = spinner('Clean output folder').start();
|
|
97
|
+
await rm(outputDir, {
|
|
98
|
+
force: true,
|
|
99
|
+
recursive: true
|
|
100
|
+
});
|
|
101
|
+
const cleanDuration = timer.end('cleanOutputFolder');
|
|
102
|
+
spin.text = `Clean output folder (${cleanDuration.toFixed(0)}ms)`;
|
|
103
|
+
spin.succeed();
|
|
104
|
+
}
|
|
105
|
+
spin = spinner(`Building Sanity application`).start();
|
|
106
|
+
const trace = getCliTelemetry().trace(AppBuildTrace);
|
|
107
|
+
trace.start();
|
|
108
|
+
let importMap;
|
|
109
|
+
if (autoUpdatesEnabled) {
|
|
110
|
+
importMap = {
|
|
111
|
+
imports: {
|
|
112
|
+
...await buildVendorDependencies({
|
|
113
|
+
basePath,
|
|
114
|
+
cwd: workDir,
|
|
115
|
+
outputDir
|
|
116
|
+
}),
|
|
117
|
+
...autoUpdatesImports
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
try {
|
|
122
|
+
timer.start('bundleStudio');
|
|
123
|
+
const bundle = await buildStaticFiles({
|
|
124
|
+
basePath,
|
|
125
|
+
cwd: workDir,
|
|
126
|
+
entry: cliConfig && 'app' in cliConfig ? cliConfig.app?.entry : undefined,
|
|
127
|
+
importMap,
|
|
128
|
+
isApp: true,
|
|
129
|
+
minify: Boolean(flags.minify),
|
|
130
|
+
outputDir,
|
|
131
|
+
reactCompiler: cliConfig && 'reactCompiler' in cliConfig ? cliConfig.reactCompiler : undefined,
|
|
132
|
+
sourceMap: Boolean(flags['source-maps']),
|
|
133
|
+
vite: cliConfig && 'vite' in cliConfig ? cliConfig.vite : undefined
|
|
134
|
+
});
|
|
135
|
+
trace.log({
|
|
136
|
+
outputSize: bundle.chunks.flatMap((chunk)=>chunk.modules.flatMap((mod)=>mod.renderedLength)).reduce((sum, n)=>sum + n, 0)
|
|
137
|
+
});
|
|
138
|
+
const buildDuration = timer.end('bundleStudio');
|
|
139
|
+
spin.text = `Build Sanity application (${buildDuration.toFixed(0)}ms)`;
|
|
140
|
+
spin.succeed();
|
|
141
|
+
if (flags.stats) {
|
|
142
|
+
output.log('\nLargest module files:');
|
|
143
|
+
output.log(formatModuleSizes(sortModulesBySize(bundle.chunks).slice(0, 15)));
|
|
144
|
+
}
|
|
145
|
+
trace.complete();
|
|
146
|
+
} catch (error) {
|
|
147
|
+
spin.fail();
|
|
148
|
+
trace.error(error);
|
|
149
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
150
|
+
buildDebug(`Failed to build Sanity application`, {
|
|
151
|
+
error
|
|
152
|
+
});
|
|
153
|
+
output.error(`Failed to build Sanity application: ${message}`, {
|
|
154
|
+
exit: 1
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
//# sourceMappingURL=buildApp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/build/buildApp.ts"],"sourcesContent":["import {rm} from 'node:fs/promises'\nimport path from 'node:path'\nimport {styleText} from 'node:util'\n\nimport {getCliTelemetry, getTimer} from '@sanity/cli-core'\nimport {confirm, logSymbols, spinner, type SpinnerInstance} from '@sanity/cli-core/ux'\nimport semver from 'semver'\n\nimport {AppBuildTrace} from '../../telemetry/build.telemetry.js'\nimport {getAppId} from '../../util/appId.js'\nimport {compareDependencyVersions} from '../../util/compareDependencyVersions.js'\nimport {formatModuleSizes, sortModulesBySize} from '../../util/moduleFormatUtils.js'\nimport {readModuleVersion} from '../../util/readModuleVersion.js'\nimport {buildDebug} from './buildDebug.js'\nimport {buildStaticFiles} from './buildStaticFiles.js'\nimport {buildVendorDependencies} from './buildVendorDependencies.js'\nimport {determineBasePath} from './determineBasePath.js'\nimport {getAppEnvVars} from './getAppEnvVars.js'\nimport {getAutoUpdatesImportMap} from './getAutoUpdatesImportMap.js'\nimport {type BuildOptions} from './types.js'\n\n/**\n * Build the Sanity app.\n *\n * @internal\n */\nexport async function buildApp(options: BuildOptions): Promise<void> {\n const {autoUpdatesEnabled, cliConfig, exit, flags, outDir, output, workDir} = options\n const unattendedMode = flags.yes\n const timer = getTimer()\n\n const defaultOutputDir = path.resolve(path.join(workDir, 'dist'))\n const outputDir = path.resolve(outDir || defaultOutputDir)\n\n const appId = getAppId(cliConfig)\n\n const installedSdkVersion = await readModuleVersion(outputDir, '@sanity/sdk-react')\n const installedSanityVersion = await readModuleVersion(outputDir, 'sanity')\n\n if (!installedSdkVersion) {\n throw new Error(`Failed to find installed @sanity/sdk-react version`)\n }\n\n let autoUpdatesImports = {}\n\n if (autoUpdatesEnabled) {\n // Get the clean version without build metadata: https://semver.org/#spec-item-10\n const cleanSDKVersion = semver.parse(installedSdkVersion)?.version\n if (!cleanSDKVersion) {\n throw new Error(`Failed to parse installed SDK version: ${installedSdkVersion}`)\n }\n\n // Sanity might not be installed, but if it is, we want to auto update it.\n const cleanSanityVersion = semver.parse(installedSanityVersion)?.version\n\n const autoUpdatedPackages = [\n {name: '@sanity/sdk', version: cleanSDKVersion},\n {name: '@sanity/sdk-react', version: cleanSDKVersion},\n ...(cleanSanityVersion ? [{name: 'sanity' as const, version: cleanSanityVersion}] : []),\n ]\n autoUpdatesImports = getAutoUpdatesImportMap(autoUpdatedPackages, {appId})\n\n output.log(`${logSymbols.info} Building with auto-updates enabled`)\n\n // Check the versions\n const result = await compareDependencyVersions(autoUpdatedPackages, workDir, {appId})\n\n // If it is in unattended mode, we don't want to prompt\n if (result?.length && !unattendedMode) {\n const shouldContinue = await confirm({\n default: false,\n message: styleText(\n 'yellow',\n `The following local package versions are different from the versions currently served at runtime.\\n` +\n `When using auto updates, we recommend that you test locally with the same versions before deploying. \\n\\n` +\n `${result.map((mod) => ` - ${mod.pkg} (local version: ${mod.installed}, runtime version: ${mod.remote})`).join('\\n')} \\n\\n` +\n `Continue anyway?`,\n ),\n })\n\n if (!shouldContinue) {\n return exit(1)\n }\n }\n }\n\n const envVarKeys = getAppEnvVars()\n if (envVarKeys.length > 0) {\n output.log('\\nIncluding the following environment variables as part of the JavaScript bundle:')\n for (const key of envVarKeys) output.log(`- ${key}`)\n output.log('')\n }\n\n let shouldClean = true\n if (outputDir !== defaultOutputDir && !unattendedMode) {\n shouldClean = await confirm({\n default: true,\n message: `Do you want to delete the existing directory (${outputDir}) first?`,\n })\n }\n\n // Determine base path for built studio\n const basePath = determineBasePath(cliConfig, 'app')\n\n let spin: SpinnerInstance\n if (shouldClean) {\n timer.start('cleanOutputFolder')\n spin = spinner('Clean output folder').start()\n await rm(outputDir, {force: true, recursive: true})\n const cleanDuration = timer.end('cleanOutputFolder')\n spin.text = `Clean output folder (${cleanDuration.toFixed(0)}ms)`\n spin.succeed()\n }\n\n spin = spinner(`Building Sanity application`).start()\n\n const trace = getCliTelemetry().trace(AppBuildTrace)\n trace.start()\n\n let importMap: {imports?: Record<string, string>} | undefined\n\n if (autoUpdatesEnabled) {\n importMap = {\n imports: {\n ...(await buildVendorDependencies({basePath, cwd: workDir, outputDir})),\n ...autoUpdatesImports,\n },\n }\n }\n\n try {\n timer.start('bundleStudio')\n\n const bundle = await buildStaticFiles({\n basePath,\n cwd: workDir,\n entry: cliConfig && 'app' in cliConfig ? cliConfig.app?.entry : undefined,\n importMap,\n isApp: true,\n minify: Boolean(flags.minify),\n outputDir,\n reactCompiler:\n cliConfig && 'reactCompiler' in cliConfig ? cliConfig.reactCompiler : undefined,\n sourceMap: Boolean(flags['source-maps']),\n vite: cliConfig && 'vite' in cliConfig ? cliConfig.vite : undefined,\n })\n\n trace.log({\n outputSize: bundle.chunks\n .flatMap((chunk) => chunk.modules.flatMap((mod) => mod.renderedLength))\n .reduce((sum, n) => sum + n, 0),\n })\n const buildDuration = timer.end('bundleStudio')\n\n spin.text = `Build Sanity application (${buildDuration.toFixed(0)}ms)`\n spin.succeed()\n\n if (flags.stats) {\n output.log('\\nLargest module files:')\n output.log(formatModuleSizes(sortModulesBySize(bundle.chunks).slice(0, 15)))\n }\n\n trace.complete()\n } catch (error) {\n spin.fail()\n trace.error(error)\n const message = error instanceof Error ? error.message : String(error)\n buildDebug(`Failed to build Sanity application`, {error})\n output.error(`Failed to build Sanity application: ${message}`, {exit: 1})\n }\n}\n"],"names":["rm","path","styleText","getCliTelemetry","getTimer","confirm","logSymbols","spinner","semver","AppBuildTrace","getAppId","compareDependencyVersions","formatModuleSizes","sortModulesBySize","readModuleVersion","buildDebug","buildStaticFiles","buildVendorDependencies","determineBasePath","getAppEnvVars","getAutoUpdatesImportMap","buildApp","options","autoUpdatesEnabled","cliConfig","exit","flags","outDir","output","workDir","unattendedMode","yes","timer","defaultOutputDir","resolve","join","outputDir","appId","installedSdkVersion","installedSanityVersion","Error","autoUpdatesImports","cleanSDKVersion","parse","version","cleanSanityVersion","autoUpdatedPackages","name","log","info","result","length","shouldContinue","default","message","map","mod","pkg","installed","remote","envVarKeys","key","shouldClean","basePath","spin","start","force","recursive","cleanDuration","end","text","toFixed","succeed","trace","importMap","imports","cwd","bundle","entry","app","undefined","isApp","minify","Boolean","reactCompiler","sourceMap","vite","outputSize","chunks","flatMap","chunk","modules","renderedLength","reduce","sum","n","buildDuration","stats","slice","complete","error","fail","String"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/build/buildDebug.ts"],"sourcesContent":["import {subdebug} from '@sanity/cli-core'\n\nexport const buildDebug = subdebug('build')\n"],"names":["subdebug","buildDebug"],"mappings":"AAAA,SAAQA,QAAQ,QAAO,mBAAkB;AAEzC,OAAO,MAAMC,aAAaD,SAAS,SAAQ"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { build } from 'vite';
|
|
3
|
+
import { copyDir } from '../../util/copyDir.js';
|
|
4
|
+
import { buildDebug } from './buildDebug.js';
|
|
5
|
+
import { extendViteConfigWithUserConfig, finalizeViteConfig, getViteConfig } from './getViteConfig.js';
|
|
6
|
+
import { writeFavicons } from './writeFavicons.js';
|
|
7
|
+
import { writeSanityRuntime } from './writeSanityRuntime.js';
|
|
8
|
+
/**
|
|
9
|
+
* Builds static files
|
|
10
|
+
*
|
|
11
|
+
* @internal
|
|
12
|
+
*/ export async function buildStaticFiles(options) {
|
|
13
|
+
const { basePath, cwd, entry, importMap, isApp, minify = true, outputDir, reactCompiler, sourceMap = false, vite: extendViteConfig } = options;
|
|
14
|
+
buildDebug('Writing Sanity runtime files');
|
|
15
|
+
await writeSanityRuntime({
|
|
16
|
+
basePath,
|
|
17
|
+
cwd,
|
|
18
|
+
entry,
|
|
19
|
+
isApp,
|
|
20
|
+
reactStrictMode: false,
|
|
21
|
+
watch: false
|
|
22
|
+
});
|
|
23
|
+
buildDebug('Resolving vite config');
|
|
24
|
+
const mode = 'production';
|
|
25
|
+
let viteConfig = await getViteConfig({
|
|
26
|
+
basePath,
|
|
27
|
+
cwd,
|
|
28
|
+
importMap,
|
|
29
|
+
isApp,
|
|
30
|
+
minify,
|
|
31
|
+
mode,
|
|
32
|
+
outputDir,
|
|
33
|
+
reactCompiler,
|
|
34
|
+
sourceMap
|
|
35
|
+
});
|
|
36
|
+
if (extendViteConfig) {
|
|
37
|
+
viteConfig = await extendViteConfigWithUserConfig({
|
|
38
|
+
command: 'build',
|
|
39
|
+
mode
|
|
40
|
+
}, viteConfig, extendViteConfig);
|
|
41
|
+
viteConfig = await finalizeViteConfig(viteConfig);
|
|
42
|
+
}
|
|
43
|
+
// Copy files placed in /static to the built /static
|
|
44
|
+
buildDebug('Copying static files from /static to output dir');
|
|
45
|
+
const staticPath = path.join(outputDir, 'static');
|
|
46
|
+
await copyDir(path.join(cwd, 'static'), staticPath);
|
|
47
|
+
// Write favicons, not overwriting ones that already exist, to static folder
|
|
48
|
+
buildDebug('Writing favicons to output dir');
|
|
49
|
+
const faviconBasePath = `${basePath.replace(/\/+$/, '')}/static`;
|
|
50
|
+
await writeFavicons(faviconBasePath, staticPath);
|
|
51
|
+
buildDebug('Bundling using vite');
|
|
52
|
+
const bundle = await build(viteConfig);
|
|
53
|
+
buildDebug('Bundling complete');
|
|
54
|
+
// For typescript only - this shouldn't ever be the case given we're not watching
|
|
55
|
+
if (Array.isArray(bundle) || !('output' in bundle)) {
|
|
56
|
+
return {
|
|
57
|
+
chunks: []
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
const stats = [];
|
|
61
|
+
for (const chunk of bundle.output){
|
|
62
|
+
if (chunk.type !== 'chunk') {
|
|
63
|
+
continue;
|
|
64
|
+
}
|
|
65
|
+
stats.push({
|
|
66
|
+
modules: Object.entries(chunk.modules).map(([rawFilePath, chunkModule])=>{
|
|
67
|
+
const filePath = rawFilePath.startsWith('\u0000') ? rawFilePath.slice('\u0000'.length) : rawFilePath;
|
|
68
|
+
return {
|
|
69
|
+
name: path.isAbsolute(filePath) ? path.relative(cwd, filePath) : filePath,
|
|
70
|
+
originalLength: chunkModule.originalLength,
|
|
71
|
+
renderedLength: chunkModule.renderedLength
|
|
72
|
+
};
|
|
73
|
+
}),
|
|
74
|
+
name: chunk.name
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
chunks: stats
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
//# sourceMappingURL=buildStaticFiles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/build/buildStaticFiles.ts"],"sourcesContent":["import path from 'node:path'\n\nimport {type UserViteConfig} from '@sanity/cli-core'\nimport {type PluginOptions as ReactCompilerConfig} from 'babel-plugin-react-compiler'\nimport {build} from 'vite'\n\nimport {copyDir} from '../../util/copyDir.js'\nimport {buildDebug} from './buildDebug.js'\nimport {extendViteConfigWithUserConfig, finalizeViteConfig, getViteConfig} from './getViteConfig.js'\nimport {writeFavicons} from './writeFavicons.js'\nimport {writeSanityRuntime} from './writeSanityRuntime.js'\n\nexport interface ChunkModule {\n name: string\n originalLength: number\n renderedLength: number\n}\n\nexport interface ChunkStats {\n modules: ChunkModule[]\n name: string\n}\n\ninterface StaticBuildOptions {\n basePath: string\n cwd: string\n outputDir: string\n\n entry?: string\n importMap?: {imports?: Record<string, string>}\n isApp?: boolean\n minify?: boolean\n profile?: boolean\n reactCompiler?: ReactCompilerConfig\n sourceMap?: boolean\n vite?: UserViteConfig\n}\n\n/**\n * Builds static files\n *\n * @internal\n */\nexport async function buildStaticFiles(\n options: StaticBuildOptions,\n): Promise<{chunks: ChunkStats[]}> {\n const {\n basePath,\n cwd,\n entry,\n importMap,\n isApp,\n minify = true,\n outputDir,\n reactCompiler,\n sourceMap = false,\n vite: extendViteConfig,\n } = options\n\n buildDebug('Writing Sanity runtime files')\n await writeSanityRuntime({\n basePath,\n cwd,\n entry,\n isApp,\n reactStrictMode: false,\n watch: false,\n })\n\n buildDebug('Resolving vite config')\n const mode = 'production'\n let viteConfig = await getViteConfig({\n basePath,\n cwd,\n importMap,\n isApp,\n minify,\n mode,\n outputDir,\n reactCompiler,\n sourceMap,\n })\n\n if (extendViteConfig) {\n viteConfig = await extendViteConfigWithUserConfig(\n {command: 'build', mode},\n viteConfig,\n extendViteConfig,\n )\n viteConfig = await finalizeViteConfig(viteConfig)\n }\n\n // Copy files placed in /static to the built /static\n buildDebug('Copying static files from /static to output dir')\n const staticPath = path.join(outputDir, 'static')\n await copyDir(path.join(cwd, 'static'), staticPath)\n\n // Write favicons, not overwriting ones that already exist, to static folder\n buildDebug('Writing favicons to output dir')\n const faviconBasePath = `${basePath.replace(/\\/+$/, '')}/static`\n await writeFavicons(faviconBasePath, staticPath)\n\n buildDebug('Bundling using vite')\n const bundle = await build(viteConfig)\n buildDebug('Bundling complete')\n\n // For typescript only - this shouldn't ever be the case given we're not watching\n if (Array.isArray(bundle) || !('output' in bundle)) {\n return {chunks: []}\n }\n\n const stats: ChunkStats[] = []\n for (const chunk of bundle.output) {\n if (chunk.type !== 'chunk') {\n continue\n }\n\n stats.push({\n modules: Object.entries(chunk.modules).map(([rawFilePath, chunkModule]) => {\n const filePath = rawFilePath.startsWith('\\u0000')\n ? rawFilePath.slice('\\u0000'.length)\n : rawFilePath\n\n return {\n name: path.isAbsolute(filePath) ? path.relative(cwd, filePath) : filePath,\n originalLength: chunkModule.originalLength,\n renderedLength: chunkModule.renderedLength,\n }\n }),\n name: chunk.name,\n })\n }\n\n return {chunks: stats}\n}\n"],"names":["path","build","copyDir","buildDebug","extendViteConfigWithUserConfig","finalizeViteConfig","getViteConfig","writeFavicons","writeSanityRuntime","buildStaticFiles","options","basePath","cwd","entry","importMap","isApp","minify","outputDir","reactCompiler","sourceMap","vite","extendViteConfig","reactStrictMode","watch","mode","viteConfig","command","staticPath","join","faviconBasePath","replace","bundle","Array","isArray","chunks","stats","chunk","output","type","push","modules","Object","entries","map","rawFilePath","chunkModule","filePath","startsWith","slice","length","name","isAbsolute","relative","originalLength","renderedLength"],"mappings":"AAAA,OAAOA,UAAU,YAAW;AAI5B,SAAQC,KAAK,QAAO,OAAM;AAE1B,SAAQC,OAAO,QAAO,wBAAuB;AAC7C,SAAQC,UAAU,QAAO,kBAAiB;AAC1C,SAAQC,8BAA8B,EAAEC,kBAAkB,EAAEC,aAAa,QAAO,qBAAoB;AACpG,SAAQC,aAAa,QAAO,qBAAoB;AAChD,SAAQC,kBAAkB,QAAO,0BAAyB;AA4B1D;;;;CAIC,GACD,OAAO,eAAeC,iBACpBC,OAA2B;IAE3B,MAAM,EACJC,QAAQ,EACRC,GAAG,EACHC,KAAK,EACLC,SAAS,EACTC,KAAK,EACLC,SAAS,IAAI,EACbC,SAAS,EACTC,aAAa,EACbC,YAAY,KAAK,EACjBC,MAAMC,gBAAgB,EACvB,GAAGX;IAEJP,WAAW;IACX,MAAMK,mBAAmB;QACvBG;QACAC;QACAC;QACAE;QACAO,iBAAiB;QACjBC,OAAO;IACT;IAEApB,WAAW;IACX,MAAMqB,OAAO;IACb,IAAIC,aAAa,MAAMnB,cAAc;QACnCK;QACAC;QACAE;QACAC;QACAC;QACAQ;QACAP;QACAC;QACAC;IACF;IAEA,IAAIE,kBAAkB;QACpBI,aAAa,MAAMrB,+BACjB;YAACsB,SAAS;YAASF;QAAI,GACvBC,YACAJ;QAEFI,aAAa,MAAMpB,mBAAmBoB;IACxC;IAEA,oDAAoD;IACpDtB,WAAW;IACX,MAAMwB,aAAa3B,KAAK4B,IAAI,CAACX,WAAW;IACxC,MAAMf,QAAQF,KAAK4B,IAAI,CAAChB,KAAK,WAAWe;IAExC,4EAA4E;IAC5ExB,WAAW;IACX,MAAM0B,kBAAkB,GAAGlB,SAASmB,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC;IAChE,MAAMvB,cAAcsB,iBAAiBF;IAErCxB,WAAW;IACX,MAAM4B,SAAS,MAAM9B,MAAMwB;IAC3BtB,WAAW;IAEX,iFAAiF;IACjF,IAAI6B,MAAMC,OAAO,CAACF,WAAW,CAAE,CAAA,YAAYA,MAAK,GAAI;QAClD,OAAO;YAACG,QAAQ,EAAE;QAAA;IACpB;IAEA,MAAMC,QAAsB,EAAE;IAC9B,KAAK,MAAMC,SAASL,OAAOM,MAAM,CAAE;QACjC,IAAID,MAAME,IAAI,KAAK,SAAS;YAC1B;QACF;QAEAH,MAAMI,IAAI,CAAC;YACTC,SAASC,OAAOC,OAAO,CAACN,MAAMI,OAAO,EAAEG,GAAG,CAAC,CAAC,CAACC,aAAaC,YAAY;gBACpE,MAAMC,WAAWF,YAAYG,UAAU,CAAC,YACpCH,YAAYI,KAAK,CAAC,SAASC,MAAM,IACjCL;gBAEJ,OAAO;oBACLM,MAAMlD,KAAKmD,UAAU,CAACL,YAAY9C,KAAKoD,QAAQ,CAACxC,KAAKkC,YAAYA;oBACjEO,gBAAgBR,YAAYQ,cAAc;oBAC1CC,gBAAgBT,YAAYS,cAAc;gBAC5C;YACF;YACAJ,MAAMd,MAAMc,IAAI;QAClB;IACF;IAEA,OAAO;QAAChB,QAAQC;IAAK;AACvB"}
|