@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,101 @@
|
|
|
1
|
+
import { createBooleanFilters } from '../gen2/filters/booleanFilters.js';
|
|
2
|
+
import { createDateFilters } from '../gen2/filters/dateFilters.js';
|
|
3
|
+
import { createDateTimeFilters } from '../gen2/filters/dateTimeFilters.js';
|
|
4
|
+
import { createFloatFilters } from '../gen2/filters/floatFilters.js';
|
|
5
|
+
import { createIdFilters } from '../gen2/filters/idFilters.js';
|
|
6
|
+
import { createIntegerFilters } from '../gen2/filters/integerFilters.js';
|
|
7
|
+
import { createStringFilters } from '../gen2/filters/stringFilters.js';
|
|
8
|
+
import { isDocumentType, isNonUnion, isUnion } from '../helpers.js';
|
|
9
|
+
import { createDocumentFilters } from './filters/documentFilters.js';
|
|
10
|
+
import { getFilterFieldName } from './utils.js';
|
|
11
|
+
const typeAliases = {
|
|
12
|
+
Email: 'String',
|
|
13
|
+
Text: 'String',
|
|
14
|
+
Url: 'String'
|
|
15
|
+
};
|
|
16
|
+
const filterCreators = {
|
|
17
|
+
Boolean: createBooleanFilters,
|
|
18
|
+
Date: createDateFilters,
|
|
19
|
+
Datetime: createDateTimeFilters,
|
|
20
|
+
Document: createDocumentFilters,
|
|
21
|
+
Float: createFloatFilters,
|
|
22
|
+
ID: createIdFilters,
|
|
23
|
+
Integer: createIntegerFilters,
|
|
24
|
+
String: createStringFilters
|
|
25
|
+
};
|
|
26
|
+
export function generateTypeFilters(types, options) {
|
|
27
|
+
const { filterSuffix } = options || {};
|
|
28
|
+
const builtInTypeKeys = Object.keys(filterCreators);
|
|
29
|
+
const builtinTypeValues = Object.values(filterCreators);
|
|
30
|
+
const objectTypes = types.filter((type)=>isNonUnion(type)).filter((type)=>type.type === 'Object' && ![
|
|
31
|
+
'Block',
|
|
32
|
+
'Span'
|
|
33
|
+
].includes(type.name) && // TODO: What do we do with blocks?
|
|
34
|
+
!type.interfaces && !builtInTypeKeys.includes(type.type));
|
|
35
|
+
const unionTypes = types.filter((type)=>isUnion(type)).map((type)=>type.name);
|
|
36
|
+
const documentTypes = types.filter((type)=>type.name === 'Document' || isDocumentType(type));
|
|
37
|
+
const builtinTypeFilters = createBuiltinTypeFilters(builtinTypeValues);
|
|
38
|
+
const objectTypeFilters = createObjectTypeFilters(objectTypes, {
|
|
39
|
+
filterSuffix,
|
|
40
|
+
unionTypes
|
|
41
|
+
});
|
|
42
|
+
const documentTypeFilters = createDocumentTypeFilters(documentTypes, {
|
|
43
|
+
filterSuffix,
|
|
44
|
+
unionTypes
|
|
45
|
+
});
|
|
46
|
+
return [
|
|
47
|
+
...builtinTypeFilters,
|
|
48
|
+
...objectTypeFilters,
|
|
49
|
+
...documentTypeFilters
|
|
50
|
+
];
|
|
51
|
+
}
|
|
52
|
+
function createBuiltinTypeFilters(builtinTypeValues) {
|
|
53
|
+
return builtinTypeValues.map((filterCreator)=>filterCreator());
|
|
54
|
+
}
|
|
55
|
+
function createObjectTypeFilters(objectTypes, options) {
|
|
56
|
+
return objectTypes.map((objectType)=>({
|
|
57
|
+
fields: createFieldFilters(objectType, options),
|
|
58
|
+
kind: 'InputObject',
|
|
59
|
+
name: getFilterFieldName(objectType.name, options.filterSuffix)
|
|
60
|
+
}));
|
|
61
|
+
}
|
|
62
|
+
function createDocumentTypeFilters(documentTypes, options) {
|
|
63
|
+
return documentTypes.map((documentType)=>({
|
|
64
|
+
fields: [
|
|
65
|
+
...getDocumentFilters(),
|
|
66
|
+
...createFieldFilters(documentType, options)
|
|
67
|
+
],
|
|
68
|
+
kind: 'InputObject',
|
|
69
|
+
name: getFilterFieldName(documentType.name, options.filterSuffix)
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
function createFieldFilters(objectType, options) {
|
|
73
|
+
const { unionTypes } = options;
|
|
74
|
+
if (!objectType.fields) {
|
|
75
|
+
return [];
|
|
76
|
+
}
|
|
77
|
+
return objectType.fields.filter((field)=>field.type !== 'JSON' && field.kind !== 'List' && !unionTypes.includes(field.type)).map((field)=>{
|
|
78
|
+
const typeName = typeAliases[field.type] || field.type;
|
|
79
|
+
// If the type is default type than don't add a custom suffix
|
|
80
|
+
const filterSuffix = Object.keys({
|
|
81
|
+
...typeAliases,
|
|
82
|
+
...filterCreators
|
|
83
|
+
}).includes(typeName) ? undefined : options.filterSuffix;
|
|
84
|
+
return {
|
|
85
|
+
fieldName: field.fieldName,
|
|
86
|
+
isReference: field.isReference,
|
|
87
|
+
type: getFilterFieldName(typeAliases[field.type] || field.type, filterSuffix)
|
|
88
|
+
};
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
function getDocumentFilters() {
|
|
92
|
+
return [
|
|
93
|
+
{
|
|
94
|
+
description: 'Apply filters on document level',
|
|
95
|
+
fieldName: '_',
|
|
96
|
+
type: 'Sanity_DocumentFilter'
|
|
97
|
+
}
|
|
98
|
+
];
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
//# sourceMappingURL=generateTypeFilters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/actions/graphql/gen3/generateTypeFilters.ts"],"sourcesContent":["import {createBooleanFilters} from '../gen2/filters/booleanFilters.js'\nimport {createDateFilters} from '../gen2/filters/dateFilters.js'\nimport {createDateTimeFilters} from '../gen2/filters/dateTimeFilters.js'\nimport {createFloatFilters} from '../gen2/filters/floatFilters.js'\nimport {createIdFilters} from '../gen2/filters/idFilters.js'\nimport {createIntegerFilters} from '../gen2/filters/integerFilters.js'\nimport {createStringFilters} from '../gen2/filters/stringFilters.js'\nimport {isDocumentType, isNonUnion, isUnion} from '../helpers.js'\nimport {\n type ApiCustomizationOptions,\n type ConvertedDocumentType,\n type ConvertedType,\n type ConvertedUnion,\n type InputObjectType,\n} from '../types.js'\nimport {createDocumentFilters} from './filters/documentFilters.js'\nimport {getFilterFieldName} from './utils.js'\n\nconst typeAliases: Record<string, string | undefined> = {\n Email: 'String',\n Text: 'String',\n Url: 'String',\n}\n\ntype FilterCreator = () => InputObjectType\n\nconst filterCreators: Record<string, FilterCreator> = {\n Boolean: createBooleanFilters,\n Date: createDateFilters,\n Datetime: createDateTimeFilters,\n Document: createDocumentFilters,\n Float: createFloatFilters,\n ID: createIdFilters,\n Integer: createIntegerFilters,\n String: createStringFilters,\n}\n\nexport function generateTypeFilters(\n types: (ConvertedType | ConvertedUnion)[],\n options?: ApiCustomizationOptions,\n): InputObjectType[] {\n const {filterSuffix} = options || {}\n const builtInTypeKeys = Object.keys(filterCreators)\n const builtinTypeValues = Object.values(filterCreators)\n const objectTypes = types\n .filter((type) => isNonUnion(type))\n .filter(\n (type) =>\n type.type === 'Object' &&\n !['Block', 'Span'].includes(type.name) && // TODO: What do we do with blocks?\n !type.interfaces &&\n !builtInTypeKeys.includes(type.type),\n )\n\n const unionTypes = types.filter((type) => isUnion(type)).map((type) => type.name)\n const documentTypes = types.filter(\n (type): type is ConvertedDocumentType => type.name === 'Document' || isDocumentType(type),\n )\n\n const builtinTypeFilters = createBuiltinTypeFilters(builtinTypeValues)\n const objectTypeFilters = createObjectTypeFilters(objectTypes, {filterSuffix, unionTypes})\n const documentTypeFilters = createDocumentTypeFilters(documentTypes, {filterSuffix, unionTypes})\n\n return [...builtinTypeFilters, ...objectTypeFilters, ...documentTypeFilters]\n}\n\nfunction createBuiltinTypeFilters(builtinTypeValues: FilterCreator[]): InputObjectType[] {\n return builtinTypeValues.map((filterCreator) => filterCreator())\n}\n\nfunction createObjectTypeFilters(\n objectTypes: ConvertedType[],\n options: {filterSuffix?: string; unionTypes: string[]},\n): InputObjectType[] {\n return objectTypes.map((objectType) => ({\n fields: createFieldFilters(objectType, options),\n kind: 'InputObject',\n name: getFilterFieldName(objectType.name, options.filterSuffix),\n }))\n}\n\nfunction createDocumentTypeFilters(\n documentTypes: ConvertedType[],\n options: {filterSuffix?: string; unionTypes: string[]},\n): InputObjectType[] {\n return documentTypes.map((documentType) => ({\n fields: [...getDocumentFilters(), ...createFieldFilters(documentType, options)],\n kind: 'InputObject',\n name: getFilterFieldName(documentType.name, options.filterSuffix),\n }))\n}\n\nfunction createFieldFilters(\n objectType: ConvertedType,\n options: {filterSuffix?: string; unionTypes: string[]},\n) {\n const {unionTypes} = options\n if (!objectType.fields) {\n return []\n }\n\n return objectType.fields\n .filter(\n (field) => field.type !== 'JSON' && field.kind !== 'List' && !unionTypes.includes(field.type),\n )\n .map((field) => {\n const typeName = typeAliases[field.type] || field.type\n // If the type is default type than don't add a custom suffix\n const filterSuffix = Object.keys({...typeAliases, ...filterCreators}).includes(typeName)\n ? undefined\n : options.filterSuffix\n\n return {\n fieldName: field.fieldName,\n isReference: field.isReference,\n type: getFilterFieldName(typeAliases[field.type] || field.type, filterSuffix),\n }\n })\n}\n\nfunction getDocumentFilters() {\n return [\n {\n description: 'Apply filters on document level',\n fieldName: '_',\n type: 'Sanity_DocumentFilter',\n },\n ]\n}\n"],"names":["createBooleanFilters","createDateFilters","createDateTimeFilters","createFloatFilters","createIdFilters","createIntegerFilters","createStringFilters","isDocumentType","isNonUnion","isUnion","createDocumentFilters","getFilterFieldName","typeAliases","Email","Text","Url","filterCreators","Boolean","Date","Datetime","Document","Float","ID","Integer","String","generateTypeFilters","types","options","filterSuffix","builtInTypeKeys","Object","keys","builtinTypeValues","values","objectTypes","filter","type","includes","name","interfaces","unionTypes","map","documentTypes","builtinTypeFilters","createBuiltinTypeFilters","objectTypeFilters","createObjectTypeFilters","documentTypeFilters","createDocumentTypeFilters","filterCreator","objectType","fields","createFieldFilters","kind","documentType","getDocumentFilters","field","typeName","undefined","fieldName","isReference","description"],"mappings":"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"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { upperFirst } from 'lodash-es';
|
|
2
|
+
import { isDocumentType, isUnion } from '../helpers.js';
|
|
3
|
+
import { internal } from '../types.js';
|
|
4
|
+
import { getFilterFieldName } from './utils.js';
|
|
5
|
+
export function generateTypeQueries(types, sortings, options) {
|
|
6
|
+
const { filterSuffix } = options || {};
|
|
7
|
+
const queries = [];
|
|
8
|
+
const documentTypes = types.filter((type)=>isDocumentType(type));
|
|
9
|
+
const documentTypeNames = documentTypes.map((docType)=>JSON.stringify(docType.originalName || docType.name));
|
|
10
|
+
const documentsFilter = `_type in [${documentTypeNames.join(', ')}]`;
|
|
11
|
+
const documentInterface = types.find((type)=>type.name === 'Document');
|
|
12
|
+
if (!documentInterface || isUnion(documentInterface)) {
|
|
13
|
+
throw new Error('Failed to find document interface');
|
|
14
|
+
}
|
|
15
|
+
const queryable = [
|
|
16
|
+
...documentTypes,
|
|
17
|
+
documentInterface
|
|
18
|
+
];
|
|
19
|
+
const isSortable = (type)=>sortings.some((sorting)=>sorting.name === `${type.name}Sorting`);
|
|
20
|
+
// Single ID-based result lookup queries
|
|
21
|
+
for (const type of queryable){
|
|
22
|
+
queries.push({
|
|
23
|
+
args: [
|
|
24
|
+
{
|
|
25
|
+
description: `${type.name} document ID`,
|
|
26
|
+
isNullable: false,
|
|
27
|
+
name: 'id',
|
|
28
|
+
type: 'ID'
|
|
29
|
+
}
|
|
30
|
+
],
|
|
31
|
+
constraints: [
|
|
32
|
+
{
|
|
33
|
+
comparator: 'eq',
|
|
34
|
+
field: '_id',
|
|
35
|
+
value: {
|
|
36
|
+
argName: 'id',
|
|
37
|
+
kind: 'argumentValue'
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
],
|
|
41
|
+
fieldName: type.name,
|
|
42
|
+
type: type.name,
|
|
43
|
+
...getDeprecation(type)
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
// Fetch all of type
|
|
47
|
+
for (const type of queryable){
|
|
48
|
+
const sorting = [];
|
|
49
|
+
if (isSortable(type)) {
|
|
50
|
+
sorting.push({
|
|
51
|
+
name: 'sort',
|
|
52
|
+
type: {
|
|
53
|
+
children: {
|
|
54
|
+
isNullable: false,
|
|
55
|
+
type: `${type.name}Sorting`
|
|
56
|
+
},
|
|
57
|
+
isNullable: true,
|
|
58
|
+
kind: 'List'
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
queries.push({
|
|
63
|
+
args: [
|
|
64
|
+
{
|
|
65
|
+
isFieldFilter: true,
|
|
66
|
+
name: 'where',
|
|
67
|
+
type: getFilterFieldName(type.name, filterSuffix)
|
|
68
|
+
},
|
|
69
|
+
...sorting,
|
|
70
|
+
{
|
|
71
|
+
description: 'Max documents to return',
|
|
72
|
+
isFieldFilter: false,
|
|
73
|
+
name: 'limit',
|
|
74
|
+
type: 'Int'
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
description: 'Offset at which to start returning documents from',
|
|
78
|
+
isFieldFilter: false,
|
|
79
|
+
name: 'offset',
|
|
80
|
+
type: 'Int'
|
|
81
|
+
}
|
|
82
|
+
],
|
|
83
|
+
fieldName: `all${upperFirst(type.name)}`,
|
|
84
|
+
filter: type.name === 'Document' && type.kind === 'Interface' ? documentsFilter : `_type == ${JSON.stringify(type.originalName || type.name)}`,
|
|
85
|
+
type: {
|
|
86
|
+
children: {
|
|
87
|
+
isNullable: false,
|
|
88
|
+
type: type.name
|
|
89
|
+
},
|
|
90
|
+
isNullable: false,
|
|
91
|
+
kind: 'List'
|
|
92
|
+
},
|
|
93
|
+
...getDeprecation(type)
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
return queries;
|
|
97
|
+
}
|
|
98
|
+
function getDeprecation(type) {
|
|
99
|
+
return type[internal]?.deprecationReason ? {
|
|
100
|
+
deprecationReason: type[internal].deprecationReason
|
|
101
|
+
} : {};
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
//# sourceMappingURL=generateTypeQueries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/actions/graphql/gen3/generateTypeQueries.ts"],"sourcesContent":["import {upperFirst} from 'lodash-es'\n\nimport {isDocumentType, isUnion} from '../helpers.js'\nimport {\n type ApiCustomizationOptions,\n type ConvertedType,\n type ConvertedUnion,\n type Deprecation,\n type InputObjectType,\n internal,\n type QueryDefinition,\n} from '../types.js'\nimport {getFilterFieldName} from './utils.js'\n\nexport function generateTypeQueries(\n types: (ConvertedType | ConvertedUnion)[],\n sortings: InputObjectType[],\n options?: ApiCustomizationOptions,\n): QueryDefinition[] {\n const {filterSuffix} = options || {}\n const queries: QueryDefinition[] = []\n const documentTypes = types.filter((type) => isDocumentType(type))\n\n const documentTypeNames = documentTypes.map((docType) =>\n JSON.stringify(docType.originalName || docType.name),\n )\n const documentsFilter = `_type in [${documentTypeNames.join(', ')}]`\n\n const documentInterface = types.find((type) => type.name === 'Document')\n if (!documentInterface || isUnion(documentInterface)) {\n throw new Error('Failed to find document interface')\n }\n\n const queryable = [...documentTypes, documentInterface]\n const isSortable = (type: ConvertedType) =>\n sortings.some((sorting) => sorting.name === `${type.name}Sorting`)\n\n // Single ID-based result lookup queries\n for (const type of queryable) {\n queries.push({\n args: [\n {\n description: `${type.name} document ID`,\n isNullable: false,\n name: 'id',\n type: 'ID',\n },\n ],\n constraints: [\n {\n comparator: 'eq',\n field: '_id',\n value: {argName: 'id', kind: 'argumentValue'},\n },\n ],\n fieldName: type.name,\n type: type.name,\n ...getDeprecation(type),\n })\n }\n\n // Fetch all of type\n for (const type of queryable) {\n const sorting: QueryDefinition['args'] = []\n if (isSortable(type)) {\n sorting.push({\n name: 'sort',\n type: {\n children: {\n isNullable: false,\n type: `${type.name}Sorting`,\n },\n isNullable: true,\n kind: 'List',\n },\n })\n }\n\n queries.push({\n args: [\n {\n isFieldFilter: true,\n name: 'where',\n type: getFilterFieldName(type.name, filterSuffix),\n },\n ...sorting,\n {\n description: 'Max documents to return',\n isFieldFilter: false,\n name: 'limit',\n type: 'Int',\n },\n {\n description: 'Offset at which to start returning documents from',\n isFieldFilter: false,\n name: 'offset',\n type: 'Int',\n },\n ],\n fieldName: `all${upperFirst(type.name)}`,\n filter:\n type.name === 'Document' && type.kind === 'Interface'\n ? documentsFilter\n : `_type == ${JSON.stringify(type.originalName || type.name)}`,\n type: {\n children: {isNullable: false, type: type.name},\n isNullable: false,\n kind: 'List',\n },\n ...getDeprecation(type),\n })\n }\n\n return queries\n}\n\nfunction getDeprecation(type: ConvertedType): Partial<Deprecation> {\n return type[internal]?.deprecationReason\n ? {\n deprecationReason: type[internal].deprecationReason,\n }\n : {}\n}\n"],"names":["upperFirst","isDocumentType","isUnion","internal","getFilterFieldName","generateTypeQueries","types","sortings","options","filterSuffix","queries","documentTypes","filter","type","documentTypeNames","map","docType","JSON","stringify","originalName","name","documentsFilter","join","documentInterface","find","Error","queryable","isSortable","some","sorting","push","args","description","isNullable","constraints","comparator","field","value","argName","kind","fieldName","getDeprecation","children","isFieldFilter","deprecationReason"],"mappings":"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"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { isDocumentType, isNonUnion } from '../helpers.js';
|
|
2
|
+
const builtInTypes = new Set([
|
|
3
|
+
'Boolean',
|
|
4
|
+
'Date',
|
|
5
|
+
'Datetime',
|
|
6
|
+
'Email',
|
|
7
|
+
'Float',
|
|
8
|
+
'ID',
|
|
9
|
+
'Integer',
|
|
10
|
+
'String',
|
|
11
|
+
'Text',
|
|
12
|
+
'Url'
|
|
13
|
+
]);
|
|
14
|
+
const builtInSortingEnum = {
|
|
15
|
+
kind: 'Enum',
|
|
16
|
+
name: 'SortOrder',
|
|
17
|
+
values: [
|
|
18
|
+
{
|
|
19
|
+
description: 'Sorts on the value in ascending order.',
|
|
20
|
+
name: 'ASC',
|
|
21
|
+
value: 1
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
description: 'Sorts on the value in descending order.',
|
|
25
|
+
name: 'DESC',
|
|
26
|
+
value: 2
|
|
27
|
+
}
|
|
28
|
+
]
|
|
29
|
+
};
|
|
30
|
+
export function generateTypeSortings(types) {
|
|
31
|
+
const objectTypes = types.filter((type)=>isNonUnion(type)).filter((type)=>type.type === 'Object' && ![
|
|
32
|
+
'Block',
|
|
33
|
+
'Span'
|
|
34
|
+
].includes(type.name) && // TODO: What do we do with blocks?
|
|
35
|
+
!type.interfaces && !builtInTypes.has(type.name));
|
|
36
|
+
const documentTypes = types.filter((type)=>type.name === 'Document' || isDocumentType(type));
|
|
37
|
+
const hasFields = (type)=>type.fields.length > 0;
|
|
38
|
+
const objectTypeSortings = createObjectTypeSortings(objectTypes);
|
|
39
|
+
const documentTypeSortings = createDocumentTypeSortings(documentTypes);
|
|
40
|
+
const allSortings = [
|
|
41
|
+
...objectTypeSortings,
|
|
42
|
+
...documentTypeSortings
|
|
43
|
+
].filter((type)=>hasFields(type));
|
|
44
|
+
return [
|
|
45
|
+
...allSortings,
|
|
46
|
+
builtInSortingEnum
|
|
47
|
+
];
|
|
48
|
+
}
|
|
49
|
+
function createObjectTypeSortings(objectTypes) {
|
|
50
|
+
return objectTypes.map((objectType)=>({
|
|
51
|
+
fields: objectType.fields.filter((field)=>field.type !== 'JSON' && field.kind !== 'List').filter((field)=>!field.isReference).map((field)=>({
|
|
52
|
+
fieldName: field.fieldName,
|
|
53
|
+
type: builtInTypes.has(field.type) ? builtInSortingEnum.name : `${field.type}Sorting`
|
|
54
|
+
})),
|
|
55
|
+
kind: 'InputObject',
|
|
56
|
+
name: `${objectType.name}Sorting`
|
|
57
|
+
}));
|
|
58
|
+
}
|
|
59
|
+
function createDocumentTypeSortings(documentTypes) {
|
|
60
|
+
return documentTypes.map((documentType)=>({
|
|
61
|
+
fields: documentType.fields.filter((field)=>field.type !== 'JSON' && field.kind !== 'List').filter((field)=>!field.isReference).map((field)=>({
|
|
62
|
+
fieldName: field.fieldName,
|
|
63
|
+
type: builtInTypes.has(field.type) ? builtInSortingEnum.name : `${field.type}Sorting`
|
|
64
|
+
})),
|
|
65
|
+
kind: 'InputObject',
|
|
66
|
+
name: `${documentType.name}Sorting`
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
//# sourceMappingURL=generateTypeSortings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/actions/graphql/gen3/generateTypeSortings.ts"],"sourcesContent":["import {isDocumentType, isNonUnion} from '../helpers.js'\nimport {\n type ConvertedDocumentType,\n type ConvertedEnum,\n type ConvertedType,\n type ConvertedUnion,\n type InputObjectType,\n} from '../types.js'\n\nconst builtInTypes = new Set([\n 'Boolean',\n 'Date',\n 'Datetime',\n 'Email',\n 'Float',\n 'ID',\n 'Integer',\n 'String',\n 'Text',\n 'Url',\n])\n\nconst builtInSortingEnum: ConvertedEnum = {\n kind: 'Enum',\n name: 'SortOrder',\n values: [\n {\n description: 'Sorts on the value in ascending order.',\n name: 'ASC',\n value: 1,\n },\n {\n description: 'Sorts on the value in descending order.',\n name: 'DESC',\n value: 2,\n },\n ],\n}\n\nexport function generateTypeSortings(\n types: (ConvertedType | ConvertedUnion)[],\n): (ConvertedEnum | InputObjectType)[] {\n const objectTypes = types\n .filter((type) => isNonUnion(type))\n .filter(\n (type) =>\n type.type === 'Object' &&\n !['Block', 'Span'].includes(type.name) && // TODO: What do we do with blocks?\n !type.interfaces &&\n !builtInTypes.has(type.name),\n )\n const documentTypes = types.filter(\n (type): type is ConvertedDocumentType => type.name === 'Document' || isDocumentType(type),\n )\n\n const hasFields = (type: InputObjectType) => type.fields.length > 0\n\n const objectTypeSortings = createObjectTypeSortings(objectTypes)\n const documentTypeSortings = createDocumentTypeSortings(documentTypes)\n const allSortings = [...objectTypeSortings, ...documentTypeSortings].filter((type) =>\n hasFields(type),\n )\n\n return [...allSortings, builtInSortingEnum]\n}\n\nfunction createObjectTypeSortings(objectTypes: ConvertedType[]): InputObjectType[] {\n return objectTypes.map((objectType) => ({\n fields: objectType.fields\n .filter((field) => field.type !== 'JSON' && field.kind !== 'List')\n .filter((field) => !field.isReference)\n .map((field) => ({\n fieldName: field.fieldName,\n type: builtInTypes.has(field.type) ? builtInSortingEnum.name : `${field.type}Sorting`,\n })),\n kind: 'InputObject',\n name: `${objectType.name}Sorting`,\n }))\n}\n\nfunction createDocumentTypeSortings(documentTypes: ConvertedType[]): InputObjectType[] {\n return documentTypes.map((documentType) => ({\n fields: documentType.fields\n .filter((field) => field.type !== 'JSON' && field.kind !== 'List')\n .filter((field) => !field.isReference)\n .map((field) => ({\n fieldName: field.fieldName,\n type: builtInTypes.has(field.type) ? builtInSortingEnum.name : `${field.type}Sorting`,\n })),\n kind: 'InputObject',\n name: `${documentType.name}Sorting`,\n }))\n}\n"],"names":["isDocumentType","isNonUnion","builtInTypes","Set","builtInSortingEnum","kind","name","values","description","value","generateTypeSortings","types","objectTypes","filter","type","includes","interfaces","has","documentTypes","hasFields","fields","length","objectTypeSortings","createObjectTypeSortings","documentTypeSortings","createDocumentTypeSortings","allSortings","map","objectType","field","isReference","fieldName","documentType"],"mappings":"AAAA,SAAQA,cAAc,EAAEC,UAAU,QAAO,gBAAe;AASxD,MAAMC,eAAe,IAAIC,IAAI;IAC3B;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,MAAMC,qBAAoC;IACxCC,MAAM;IACNC,MAAM;IACNC,QAAQ;QACN;YACEC,aAAa;YACbF,MAAM;YACNG,OAAO;QACT;QACA;YACED,aAAa;YACbF,MAAM;YACNG,OAAO;QACT;KACD;AACH;AAEA,OAAO,SAASC,qBACdC,KAAyC;IAEzC,MAAMC,cAAcD,MACjBE,MAAM,CAAC,CAACC,OAASb,WAAWa,OAC5BD,MAAM,CACL,CAACC,OACCA,KAAKA,IAAI,KAAK,YACd,CAAC;YAAC;YAAS;SAAO,CAACC,QAAQ,CAACD,KAAKR,IAAI,KAAK,mCAAmC;QAC7E,CAACQ,KAAKE,UAAU,IAChB,CAACd,aAAae,GAAG,CAACH,KAAKR,IAAI;IAEjC,MAAMY,gBAAgBP,MAAME,MAAM,CAChC,CAACC,OAAwCA,KAAKR,IAAI,KAAK,cAAcN,eAAec;IAGtF,MAAMK,YAAY,CAACL,OAA0BA,KAAKM,MAAM,CAACC,MAAM,GAAG;IAElE,MAAMC,qBAAqBC,yBAAyBX;IACpD,MAAMY,uBAAuBC,2BAA2BP;IACxD,MAAMQ,cAAc;WAAIJ;WAAuBE;KAAqB,CAACX,MAAM,CAAC,CAACC,OAC3EK,UAAUL;IAGZ,OAAO;WAAIY;QAAatB;KAAmB;AAC7C;AAEA,SAASmB,yBAAyBX,WAA4B;IAC5D,OAAOA,YAAYe,GAAG,CAAC,CAACC,aAAgB,CAAA;YACtCR,QAAQQ,WAAWR,MAAM,CACtBP,MAAM,CAAC,CAACgB,QAAUA,MAAMf,IAAI,KAAK,UAAUe,MAAMxB,IAAI,KAAK,QAC1DQ,MAAM,CAAC,CAACgB,QAAU,CAACA,MAAMC,WAAW,EACpCH,GAAG,CAAC,CAACE,QAAW,CAAA;oBACfE,WAAWF,MAAME,SAAS;oBAC1BjB,MAAMZ,aAAae,GAAG,CAACY,MAAMf,IAAI,IAAIV,mBAAmBE,IAAI,GAAG,GAAGuB,MAAMf,IAAI,CAAC,OAAO,CAAC;gBACvF,CAAA;YACFT,MAAM;YACNC,MAAM,GAAGsB,WAAWtB,IAAI,CAAC,OAAO,CAAC;QACnC,CAAA;AACF;AAEA,SAASmB,2BAA2BP,aAA8B;IAChE,OAAOA,cAAcS,GAAG,CAAC,CAACK,eAAkB,CAAA;YAC1CZ,QAAQY,aAAaZ,MAAM,CACxBP,MAAM,CAAC,CAACgB,QAAUA,MAAMf,IAAI,KAAK,UAAUe,MAAMxB,IAAI,KAAK,QAC1DQ,MAAM,CAAC,CAACgB,QAAU,CAACA,MAAMC,WAAW,EACpCH,GAAG,CAAC,CAACE,QAAW,CAAA;oBACfE,WAAWF,MAAME,SAAS;oBAC1BjB,MAAMZ,aAAae,GAAG,CAACY,MAAMf,IAAI,IAAIV,mBAAmBE,IAAI,GAAG,GAAGuB,MAAMf,IAAI,CAAC,OAAO,CAAC;gBACvF,CAAA;YACFT,MAAM;YACNC,MAAM,GAAG0B,aAAa1B,IAAI,CAAC,OAAO,CAAC;QACrC,CAAA;AACF"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { isUnion } from '../helpers.js';
|
|
2
|
+
import { generateTypeFilters } from './generateTypeFilters.js';
|
|
3
|
+
import { generateTypeQueries } from './generateTypeQueries.js';
|
|
4
|
+
import { generateTypeSortings } from './generateTypeSortings.js';
|
|
5
|
+
const gen3 = (extracted, options)=>{
|
|
6
|
+
const documentInterface = extracted.interfaces.find((iface)=>iface.name === 'Document');
|
|
7
|
+
if (!documentInterface || isUnion(documentInterface)) {
|
|
8
|
+
throw new Error('Failed to find document interface');
|
|
9
|
+
}
|
|
10
|
+
const types = [
|
|
11
|
+
...extracted.types,
|
|
12
|
+
documentInterface
|
|
13
|
+
];
|
|
14
|
+
const filters = generateTypeFilters(types, options);
|
|
15
|
+
const sortings = generateTypeSortings(types);
|
|
16
|
+
const queries = generateTypeQueries(types, sortings.filter((node)=>node.kind === 'InputObject'), options);
|
|
17
|
+
const graphqlTypes = [
|
|
18
|
+
...extracted.types,
|
|
19
|
+
...filters,
|
|
20
|
+
...sortings
|
|
21
|
+
];
|
|
22
|
+
return {
|
|
23
|
+
generation: 'gen3',
|
|
24
|
+
interfaces: extracted.interfaces,
|
|
25
|
+
queries,
|
|
26
|
+
types: graphqlTypes
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
export default gen3;
|
|
30
|
+
|
|
31
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/actions/graphql/gen3/index.ts"],"sourcesContent":["import {isUnion} from '../helpers.js'\nimport {\n type ApiCustomizationOptions,\n type ApiSpecification,\n type ConvertedType,\n type GeneratedApiSpecification,\n type InputObjectType,\n} from '../types.js'\nimport {generateTypeFilters} from './generateTypeFilters.js'\nimport {generateTypeQueries} from './generateTypeQueries.js'\nimport {generateTypeSortings} from './generateTypeSortings.js'\n\nconst gen3 = (\n extracted: ApiSpecification,\n options?: ApiCustomizationOptions,\n): GeneratedApiSpecification => {\n const documentInterface = extracted.interfaces.find((iface) => iface.name === 'Document')\n if (!documentInterface || isUnion(documentInterface)) {\n throw new Error('Failed to find document interface')\n }\n\n const types = [...extracted.types, documentInterface as ConvertedType]\n\n const filters = generateTypeFilters(types, options)\n const sortings = generateTypeSortings(types)\n const queries = generateTypeQueries(\n types,\n sortings.filter((node): node is InputObjectType => node.kind === 'InputObject'),\n options,\n )\n const graphqlTypes = [...extracted.types, ...filters, ...sortings]\n\n return {generation: 'gen3', interfaces: extracted.interfaces, queries, types: graphqlTypes}\n}\n\nexport default gen3\n"],"names":["isUnion","generateTypeFilters","generateTypeQueries","generateTypeSortings","gen3","extracted","options","documentInterface","interfaces","find","iface","name","Error","types","filters","sortings","queries","filter","node","kind","graphqlTypes","generation"],"mappings":"AAAA,SAAQA,OAAO,QAAO,gBAAe;AAQrC,SAAQC,mBAAmB,QAAO,2BAA0B;AAC5D,SAAQC,mBAAmB,QAAO,2BAA0B;AAC5D,SAAQC,oBAAoB,QAAO,4BAA2B;AAE9D,MAAMC,OAAO,CACXC,WACAC;IAEA,MAAMC,oBAAoBF,UAAUG,UAAU,CAACC,IAAI,CAAC,CAACC,QAAUA,MAAMC,IAAI,KAAK;IAC9E,IAAI,CAACJ,qBAAqBP,QAAQO,oBAAoB;QACpD,MAAM,IAAIK,MAAM;IAClB;IAEA,MAAMC,QAAQ;WAAIR,UAAUQ,KAAK;QAAEN;KAAmC;IAEtE,MAAMO,UAAUb,oBAAoBY,OAAOP;IAC3C,MAAMS,WAAWZ,qBAAqBU;IACtC,MAAMG,UAAUd,oBACdW,OACAE,SAASE,MAAM,CAAC,CAACC,OAAkCA,KAAKC,IAAI,KAAK,gBACjEb;IAEF,MAAMc,eAAe;WAAIf,UAAUQ,KAAK;WAAKC;WAAYC;KAAS;IAElE,OAAO;QAACM,YAAY;QAAQb,YAAYH,UAAUG,UAAU;QAAEQ;QAASH,OAAOO;IAAY;AAC5F;AAEA,eAAehB,KAAI"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generates a filter field name for a given field name.
|
|
3
|
+
*
|
|
4
|
+
* @internal
|
|
5
|
+
*
|
|
6
|
+
* @param fieldName - The field name to generate a filter field name for.
|
|
7
|
+
* @param suffix - The suffix to append to the field name. Default is `Filter`.
|
|
8
|
+
*/ export function getFilterFieldName(fieldName, suffix = 'Filter') {
|
|
9
|
+
return `${fieldName}${suffix}`;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/actions/graphql/gen3/utils.ts"],"sourcesContent":["/**\n * Generates a filter field name for a given field name.\n *\n * @internal\n *\n * @param fieldName - The field name to generate a filter field name for.\n * @param suffix - The suffix to append to the field name. Default is `Filter`.\n */\nexport function getFilterFieldName(fieldName: string, suffix = 'Filter'): string {\n return `${fieldName}${suffix}`\n}\n"],"names":["getFilterFieldName","fieldName","suffix"],"mappings":"AAAA;;;;;;;CAOC,GACD,OAAO,SAASA,mBAAmBC,SAAiB,EAAEC,SAAS,QAAQ;IACrE,OAAO,GAAGD,YAAYC,QAAQ;AAChC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { isMainThread, Worker } from 'node:worker_threads';
|
|
2
|
+
import { getCliConfig, getStudioConfig, resolveLocalPackage } from '@sanity/cli-core';
|
|
3
|
+
import { packageDirectory } from 'package-directory';
|
|
4
|
+
export async function getGraphQLAPIs(workDir) {
|
|
5
|
+
if (!isMainThread) {
|
|
6
|
+
throw new Error('getGraphQLAPIs() must be called from the main thread');
|
|
7
|
+
}
|
|
8
|
+
// Resolve `sanity` local to the project in order to avoid using incompatible versions, and to avoid circular dependencies
|
|
9
|
+
const { createSchema } = await resolveLocalPackage('sanity', workDir);
|
|
10
|
+
const defaultSchema = createSchema({
|
|
11
|
+
name: 'default',
|
|
12
|
+
types: []
|
|
13
|
+
});
|
|
14
|
+
const defaultTypes = defaultSchema.getTypeNames();
|
|
15
|
+
const isCustomType = (type)=>!defaultTypes.includes(type.name);
|
|
16
|
+
const apis = await getApisWithSchemaTypes(workDir);
|
|
17
|
+
const resolved = apis.map(({ schemaTypes, ...api })=>({
|
|
18
|
+
schema: createSchema({
|
|
19
|
+
name: 'default',
|
|
20
|
+
types: schemaTypes.filter((element)=>isCustomType(element))
|
|
21
|
+
}),
|
|
22
|
+
...api
|
|
23
|
+
}));
|
|
24
|
+
return resolved;
|
|
25
|
+
}
|
|
26
|
+
async function getApisWithSchemaTypes(workDir) {
|
|
27
|
+
const cliConfig = await getCliConfig(workDir);
|
|
28
|
+
const workspaces = await getStudioConfig(workDir, {
|
|
29
|
+
resolvePlugins: true
|
|
30
|
+
});
|
|
31
|
+
const cliPkgDir = await packageDirectory({
|
|
32
|
+
cwd: import.meta.dirname
|
|
33
|
+
});
|
|
34
|
+
if (!cliPkgDir) {
|
|
35
|
+
throw new Error('Unable to resolve @sanity/cli module root');
|
|
36
|
+
}
|
|
37
|
+
return new Promise((resolve, reject)=>{
|
|
38
|
+
const worker = new Worker(new URL(`getGraphQLAPIs.worker.js`, import.meta.url), {
|
|
39
|
+
env: process.env,
|
|
40
|
+
workerData: {
|
|
41
|
+
cliConfig: extractGraphQLConfig(cliConfig),
|
|
42
|
+
workDir,
|
|
43
|
+
workspaces
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
worker.on('message', resolve);
|
|
47
|
+
worker.on('error', (error)=>{
|
|
48
|
+
reject(error);
|
|
49
|
+
worker.terminate();
|
|
50
|
+
});
|
|
51
|
+
worker.on('exit', (code)=>{
|
|
52
|
+
if (code !== 0) {
|
|
53
|
+
reject(new Error(`Worker stopped with exit code ${code}`));
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
function extractGraphQLConfig(config) {
|
|
59
|
+
return structuredClone({
|
|
60
|
+
api: config.api,
|
|
61
|
+
graphql: config.graphql
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
//# sourceMappingURL=getGraphQLAPIs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/graphql/getGraphQLAPIs.ts"],"sourcesContent":["import {isMainThread, Worker} from 'node:worker_threads'\n\nimport {type CliConfig, getCliConfig, getStudioConfig, resolveLocalPackage} from '@sanity/cli-core'\nimport {packageDirectory} from 'package-directory'\n\nimport {\n type ResolvedGraphQLAPI,\n type ResolvedSourceProperties,\n type SchemaDefinitionish,\n type TypeResolvedGraphQLAPI,\n} from './types.js'\n\nexport async function getGraphQLAPIs(workDir: string): Promise<ResolvedGraphQLAPI[]> {\n if (!isMainThread) {\n throw new Error('getGraphQLAPIs() must be called from the main thread')\n }\n\n // Resolve `sanity` local to the project in order to avoid using incompatible versions, and to avoid circular dependencies\n const {createSchema} = await resolveLocalPackage<typeof import('sanity')>('sanity', workDir)\n\n const defaultSchema = createSchema({name: 'default', types: []})\n const defaultTypes = defaultSchema.getTypeNames()\n const isCustomType = (type: SchemaDefinitionish) => !defaultTypes.includes(type.name)\n\n const apis = await getApisWithSchemaTypes(workDir)\n const resolved = apis.map(\n ({schemaTypes, ...api}): ResolvedSourceProperties => ({\n schema: createSchema({\n name: 'default',\n types: schemaTypes.filter((element) => isCustomType(element)),\n }),\n ...api,\n }),\n )\n\n return resolved\n}\n\nasync function getApisWithSchemaTypes(workDir: string): Promise<TypeResolvedGraphQLAPI[]> {\n const cliConfig = await getCliConfig(workDir)\n const workspaces = await getStudioConfig(workDir, {resolvePlugins: true})\n\n const cliPkgDir = await packageDirectory({cwd: import.meta.dirname})\n if (!cliPkgDir) {\n throw new Error('Unable to resolve @sanity/cli module root')\n }\n\n return new Promise<TypeResolvedGraphQLAPI[]>((resolve, reject) => {\n const worker = new Worker(new URL(`getGraphQLAPIs.worker.js`, import.meta.url), {\n env: process.env,\n workerData: {\n cliConfig: extractGraphQLConfig(cliConfig),\n workDir,\n workspaces,\n },\n })\n worker.on('message', resolve)\n worker.on('error', (error) => {\n reject(error)\n worker.terminate()\n })\n worker.on('exit', (code) => {\n if (code !== 0) {\n reject(new Error(`Worker stopped with exit code ${code}`))\n }\n })\n })\n}\n\nfunction extractGraphQLConfig(config: CliConfig) {\n return structuredClone({\n api: config.api,\n graphql: config.graphql,\n })\n}\n"],"names":["isMainThread","Worker","getCliConfig","getStudioConfig","resolveLocalPackage","packageDirectory","getGraphQLAPIs","workDir","Error","createSchema","defaultSchema","name","types","defaultTypes","getTypeNames","isCustomType","type","includes","apis","getApisWithSchemaTypes","resolved","map","schemaTypes","api","schema","filter","element","cliConfig","workspaces","resolvePlugins","cliPkgDir","cwd","dirname","Promise","resolve","reject","worker","URL","url","env","process","workerData","extractGraphQLConfig","on","error","terminate","code","config","structuredClone","graphql"],"mappings":"AAAA,SAAQA,YAAY,EAAEC,MAAM,QAAO,sBAAqB;AAExD,SAAwBC,YAAY,EAAEC,eAAe,EAAEC,mBAAmB,QAAO,mBAAkB;AACnG,SAAQC,gBAAgB,QAAO,oBAAmB;AASlD,OAAO,eAAeC,eAAeC,OAAe;IAClD,IAAI,CAACP,cAAc;QACjB,MAAM,IAAIQ,MAAM;IAClB;IAEA,0HAA0H;IAC1H,MAAM,EAACC,YAAY,EAAC,GAAG,MAAML,oBAA6C,UAAUG;IAEpF,MAAMG,gBAAgBD,aAAa;QAACE,MAAM;QAAWC,OAAO,EAAE;IAAA;IAC9D,MAAMC,eAAeH,cAAcI,YAAY;IAC/C,MAAMC,eAAe,CAACC,OAA8B,CAACH,aAAaI,QAAQ,CAACD,KAAKL,IAAI;IAEpF,MAAMO,OAAO,MAAMC,uBAAuBZ;IAC1C,MAAMa,WAAWF,KAAKG,GAAG,CACvB,CAAC,EAACC,WAAW,EAAE,GAAGC,KAAI,GAAgC,CAAA;YACpDC,QAAQf,aAAa;gBACnBE,MAAM;gBACNC,OAAOU,YAAYG,MAAM,CAAC,CAACC,UAAYX,aAAaW;YACtD;YACA,GAAGH,GAAG;QACR,CAAA;IAGF,OAAOH;AACT;AAEA,eAAeD,uBAAuBZ,OAAe;IACnD,MAAMoB,YAAY,MAAMzB,aAAaK;IACrC,MAAMqB,aAAa,MAAMzB,gBAAgBI,SAAS;QAACsB,gBAAgB;IAAI;IAEvE,MAAMC,YAAY,MAAMzB,iBAAiB;QAAC0B,KAAK,YAAYC,OAAO;IAAA;IAClE,IAAI,CAACF,WAAW;QACd,MAAM,IAAItB,MAAM;IAClB;IAEA,OAAO,IAAIyB,QAAkC,CAACC,SAASC;QACrD,MAAMC,SAAS,IAAInC,OAAO,IAAIoC,IAAI,CAAC,wBAAwB,CAAC,EAAE,YAAYC,GAAG,GAAG;YAC9EC,KAAKC,QAAQD,GAAG;YAChBE,YAAY;gBACVd,WAAWe,qBAAqBf;gBAChCpB;gBACAqB;YACF;QACF;QACAQ,OAAOO,EAAE,CAAC,WAAWT;QACrBE,OAAOO,EAAE,CAAC,SAAS,CAACC;YAClBT,OAAOS;YACPR,OAAOS,SAAS;QAClB;QACAT,OAAOO,EAAE,CAAC,QAAQ,CAACG;YACjB,IAAIA,SAAS,GAAG;gBACdX,OAAO,IAAI3B,MAAM,CAAC,8BAA8B,EAAEsC,MAAM;YAC1D;QACF;IACF;AACF;AAEA,SAASJ,qBAAqBK,MAAiB;IAC7C,OAAOC,gBAAgB;QACrBzB,KAAKwB,OAAOxB,GAAG;QACf0B,SAASF,OAAOE,OAAO;IACzB;AACF"}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { isMainThread, parentPort, workerData } from 'node:worker_threads';
|
|
2
|
+
import { isPlainObject } from 'lodash-es';
|
|
3
|
+
import { oneline } from 'oneline';
|
|
4
|
+
async function main() {
|
|
5
|
+
if (isMainThread || !parentPort) {
|
|
6
|
+
throw new Error('This module must be run as a worker thread');
|
|
7
|
+
}
|
|
8
|
+
await getGraphQLAPIsForked(parentPort);
|
|
9
|
+
}
|
|
10
|
+
await main();
|
|
11
|
+
async function getGraphQLAPIsForked(parent) {
|
|
12
|
+
const { cliConfig, workspaces } = workerData;
|
|
13
|
+
const resolved = await resolveGraphQLApis({
|
|
14
|
+
cliConfig,
|
|
15
|
+
workspaces
|
|
16
|
+
});
|
|
17
|
+
parent.postMessage(resolved);
|
|
18
|
+
}
|
|
19
|
+
async function resolveGraphQLApis({ cliConfig, workspaces }) {
|
|
20
|
+
const numSources = workspaces.reduce((count, workspace)=>count + workspace.unstable_sources.length, 0);
|
|
21
|
+
const multiSource = numSources > 1;
|
|
22
|
+
const multiWorkspace = workspaces.length > 1;
|
|
23
|
+
const hasGraphQLConfig = Boolean(cliConfig?.graphql);
|
|
24
|
+
if (workspaces.length === 0) {
|
|
25
|
+
throw new Error('No studio configuration found');
|
|
26
|
+
}
|
|
27
|
+
if (numSources === 0) {
|
|
28
|
+
throw new Error('No sources (project ID / dataset) configured');
|
|
29
|
+
}
|
|
30
|
+
// We can only automatically configure if there is a single workspace + source in play
|
|
31
|
+
if ((multiWorkspace || multiSource) && !hasGraphQLConfig) {
|
|
32
|
+
throw new Error(oneline`
|
|
33
|
+
Multiple workspaces/sources configured.
|
|
34
|
+
You must define an array of GraphQL APIs in \`sanity.cli.ts\` or \`sanity.cli.js\`
|
|
35
|
+
and specify which workspace/source to use.
|
|
36
|
+
`);
|
|
37
|
+
}
|
|
38
|
+
// No config is defined, but we have a single workspace + source, so use that
|
|
39
|
+
if (!hasGraphQLConfig) {
|
|
40
|
+
const { dataset, projectId, schema } = workspaces[0].unstable_sources[0];
|
|
41
|
+
return [
|
|
42
|
+
{
|
|
43
|
+
dataset,
|
|
44
|
+
projectId,
|
|
45
|
+
schemaTypes: getStrippedSchemaTypes(schema)
|
|
46
|
+
}
|
|
47
|
+
];
|
|
48
|
+
}
|
|
49
|
+
// Explicity defined config
|
|
50
|
+
const apiDefs = validateCliConfig(cliConfig?.graphql || []);
|
|
51
|
+
return resolveGraphQLAPIsFromConfig(apiDefs, workspaces);
|
|
52
|
+
}
|
|
53
|
+
function resolveGraphQLAPIsFromConfig(apiDefs, workspaces) {
|
|
54
|
+
const resolvedApis = [];
|
|
55
|
+
for (const apiDef of apiDefs){
|
|
56
|
+
const { source: sourceName, workspace: workspaceName } = apiDef;
|
|
57
|
+
if (!workspaceName && workspaces.length > 1) {
|
|
58
|
+
throw new Error('Must define `workspace` name in GraphQL API config when multiple workspaces are defined');
|
|
59
|
+
}
|
|
60
|
+
// If we only have a single workspace defined, we can assume that is the intended one,
|
|
61
|
+
// even if no `workspace` is defined for the GraphQL API
|
|
62
|
+
const workspace = !workspaceName && workspaces.length === 1 ? workspaces[0] : workspaces.find((space)=>space.name === (workspaceName || 'default'));
|
|
63
|
+
if (!workspace) {
|
|
64
|
+
throw new Error(`Workspace "${workspaceName || 'default'}" not found`);
|
|
65
|
+
}
|
|
66
|
+
// If we only have a single source defined, we can assume that is the intended one,
|
|
67
|
+
// even if no `source` is defined for the GraphQL API
|
|
68
|
+
const source = !sourceName && workspace.unstable_sources.length === 1 ? workspace.unstable_sources[0] : workspace.unstable_sources.find((src)=>src.name === (sourceName || 'default'));
|
|
69
|
+
if (!source) {
|
|
70
|
+
throw new Error(`Source "${sourceName || 'default'}" not found in workspace "${workspaceName || 'default'}"`);
|
|
71
|
+
}
|
|
72
|
+
resolvedApis.push({
|
|
73
|
+
...apiDef,
|
|
74
|
+
dataset: source.dataset,
|
|
75
|
+
projectId: source.projectId,
|
|
76
|
+
schemaTypes: getStrippedSchemaTypes(source.schema)
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
return resolvedApis;
|
|
80
|
+
}
|
|
81
|
+
function validateCliConfig(config, configPath = 'sanity.cli.js') {
|
|
82
|
+
if (!Array.isArray(config)) {
|
|
83
|
+
throw new TypeError(`"graphql" key in "${configPath}" must be an array if defined`);
|
|
84
|
+
}
|
|
85
|
+
if (config.length === 0) {
|
|
86
|
+
throw new Error(`No GraphQL APIs defined in "${configPath}"`);
|
|
87
|
+
}
|
|
88
|
+
return config;
|
|
89
|
+
}
|
|
90
|
+
function getStrippedSchemaTypes(schema) {
|
|
91
|
+
const schemaDef = schema._original || {
|
|
92
|
+
types: []
|
|
93
|
+
};
|
|
94
|
+
return schemaDef.types.map((type)=>stripType(type));
|
|
95
|
+
}
|
|
96
|
+
function stripType(input) {
|
|
97
|
+
return strip(input);
|
|
98
|
+
}
|
|
99
|
+
function strip(input) {
|
|
100
|
+
if (Array.isArray(input)) {
|
|
101
|
+
return input.map((item)=>strip(item)).filter((item)=>item !== undefined);
|
|
102
|
+
}
|
|
103
|
+
if (isPlainishObject(input)) {
|
|
104
|
+
const stripped = {};
|
|
105
|
+
for (const key of Object.keys(input)){
|
|
106
|
+
stripped[key] = strip(input[key]);
|
|
107
|
+
}
|
|
108
|
+
return stripped;
|
|
109
|
+
}
|
|
110
|
+
return isBasicType(input) ? input : undefined;
|
|
111
|
+
}
|
|
112
|
+
function isPlainishObject(input) {
|
|
113
|
+
return isPlainObject(input);
|
|
114
|
+
}
|
|
115
|
+
function isBasicType(input) {
|
|
116
|
+
const type = typeof input;
|
|
117
|
+
if (type === 'boolean' || type === 'number' || type === 'string') {
|
|
118
|
+
return true;
|
|
119
|
+
}
|
|
120
|
+
if (type !== 'object') {
|
|
121
|
+
return false;
|
|
122
|
+
}
|
|
123
|
+
return Array.isArray(input) || input === null || isPlainishObject(input);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
//# sourceMappingURL=getGraphQLAPIs.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/graphql/getGraphQLAPIs.worker.ts"],"sourcesContent":["import {isMainThread, type MessagePort, parentPort, workerData} from 'node:worker_threads'\n\nimport {type Schema} from '@sanity/types'\nimport {isPlainObject} from 'lodash-es'\nimport {oneline} from 'oneline'\n\nimport {\n type GraphQLAPIConfig,\n type SchemaDefinitionish,\n type TypeResolvedGraphQLAPI,\n} from './types.js'\n\ninterface Source {\n dataset: string\n name: string\n projectId: string\n schema: Schema\n}\n\ninterface Workspace extends Source {\n unstable_sources: Source[]\n}\n\nasync function main() {\n if (isMainThread || !parentPort) {\n throw new Error('This module must be run as a worker thread')\n }\n\n await getGraphQLAPIsForked(parentPort)\n}\n\nawait main()\n\nasync function getGraphQLAPIsForked(parent: MessagePort): Promise<void> {\n const {cliConfig, workspaces} = workerData\n const resolved = await resolveGraphQLApis({cliConfig, workspaces})\n parent.postMessage(resolved)\n}\n\ninterface ResolveGraphQLApisOptions {\n workspaces: Workspace[]\n\n cliConfig?: {graphql?: GraphQLAPIConfig[]}\n}\n\nasync function resolveGraphQLApis({\n cliConfig,\n workspaces,\n}: ResolveGraphQLApisOptions): Promise<TypeResolvedGraphQLAPI[]> {\n const numSources = workspaces.reduce(\n (count, workspace) => count + workspace.unstable_sources.length,\n 0,\n )\n const multiSource = numSources > 1\n const multiWorkspace = workspaces.length > 1\n const hasGraphQLConfig = Boolean(cliConfig?.graphql)\n\n if (workspaces.length === 0) {\n throw new Error('No studio configuration found')\n }\n\n if (numSources === 0) {\n throw new Error('No sources (project ID / dataset) configured')\n }\n\n // We can only automatically configure if there is a single workspace + source in play\n if ((multiWorkspace || multiSource) && !hasGraphQLConfig) {\n throw new Error(oneline`\n Multiple workspaces/sources configured.\n You must define an array of GraphQL APIs in \\`sanity.cli.ts\\` or \\`sanity.cli.js\\`\n and specify which workspace/source to use.\n `)\n }\n\n // No config is defined, but we have a single workspace + source, so use that\n if (!hasGraphQLConfig) {\n const {dataset, projectId, schema} = workspaces[0].unstable_sources[0]\n return [{dataset, projectId, schemaTypes: getStrippedSchemaTypes(schema)}]\n }\n\n // Explicity defined config\n const apiDefs = validateCliConfig(cliConfig?.graphql || [])\n return resolveGraphQLAPIsFromConfig(apiDefs, workspaces)\n}\n\nfunction resolveGraphQLAPIsFromConfig(\n apiDefs: GraphQLAPIConfig[],\n workspaces: Workspace[],\n): TypeResolvedGraphQLAPI[] {\n const resolvedApis: TypeResolvedGraphQLAPI[] = []\n\n for (const apiDef of apiDefs) {\n const {source: sourceName, workspace: workspaceName} = apiDef\n if (!workspaceName && workspaces.length > 1) {\n throw new Error(\n 'Must define `workspace` name in GraphQL API config when multiple workspaces are defined',\n )\n }\n\n // If we only have a single workspace defined, we can assume that is the intended one,\n // even if no `workspace` is defined for the GraphQL API\n const workspace =\n !workspaceName && workspaces.length === 1\n ? workspaces[0]\n : workspaces.find((space) => space.name === (workspaceName || 'default'))\n\n if (!workspace) {\n throw new Error(`Workspace \"${workspaceName || 'default'}\" not found`)\n }\n\n // If we only have a single source defined, we can assume that is the intended one,\n // even if no `source` is defined for the GraphQL API\n const source =\n !sourceName && workspace.unstable_sources.length === 1\n ? workspace.unstable_sources[0]\n : workspace.unstable_sources.find((src) => src.name === (sourceName || 'default'))\n\n if (!source) {\n throw new Error(\n `Source \"${sourceName || 'default'}\" not found in workspace \"${\n workspaceName || 'default'\n }\"`,\n )\n }\n\n resolvedApis.push({\n ...apiDef,\n dataset: source.dataset,\n projectId: source.projectId,\n schemaTypes: getStrippedSchemaTypes(source.schema),\n })\n }\n\n return resolvedApis\n}\n\nfunction validateCliConfig(\n config: GraphQLAPIConfig[],\n configPath = 'sanity.cli.js',\n): GraphQLAPIConfig[] {\n if (!Array.isArray(config)) {\n throw new TypeError(`\"graphql\" key in \"${configPath}\" must be an array if defined`)\n }\n\n if (config.length === 0) {\n throw new Error(`No GraphQL APIs defined in \"${configPath}\"`)\n }\n\n return config\n}\n\nfunction getStrippedSchemaTypes(schema: Schema): SchemaDefinitionish[] {\n const schemaDef = schema._original || {types: []}\n return schemaDef.types.map((type) => stripType(type))\n}\n\nfunction stripType(input: unknown): SchemaDefinitionish {\n return strip(input) as SchemaDefinitionish\n}\n\nfunction strip(input: unknown): unknown {\n if (Array.isArray(input)) {\n return input.map((item) => strip(item)).filter((item) => item !== undefined)\n }\n\n if (isPlainishObject(input)) {\n const stripped: Record<string, unknown> = {}\n for (const key of Object.keys(input)) {\n stripped[key] = strip(input[key])\n }\n return stripped\n }\n\n return isBasicType(input) ? input : undefined\n}\n\nfunction isPlainishObject(input: unknown): input is Record<string, unknown> {\n return isPlainObject(input)\n}\n\nfunction isBasicType(input: unknown): boolean {\n const type = typeof input\n if (type === 'boolean' || type === 'number' || type === 'string') {\n return true\n }\n\n if (type !== 'object') {\n return false\n }\n\n return Array.isArray(input) || input === null || isPlainishObject(input)\n}\n"],"names":["isMainThread","parentPort","workerData","isPlainObject","oneline","main","Error","getGraphQLAPIsForked","parent","cliConfig","workspaces","resolved","resolveGraphQLApis","postMessage","numSources","reduce","count","workspace","unstable_sources","length","multiSource","multiWorkspace","hasGraphQLConfig","Boolean","graphql","dataset","projectId","schema","schemaTypes","getStrippedSchemaTypes","apiDefs","validateCliConfig","resolveGraphQLAPIsFromConfig","resolvedApis","apiDef","source","sourceName","workspaceName","find","space","name","src","push","config","configPath","Array","isArray","TypeError","schemaDef","_original","types","map","type","stripType","input","strip","item","filter","undefined","isPlainishObject","stripped","key","Object","keys","isBasicType"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/graphql/graphqlDebug.ts"],"sourcesContent":["import {subdebug} from '@sanity/cli-core'\n\nexport const graphqlDebug = subdebug('graphql')\n"],"names":["subdebug","graphqlDebug"],"mappings":"AAAA,SAAQA,QAAQ,QAAO,mBAAkB;AAEzC,OAAO,MAAMC,eAAeD,SAAS,WAAU"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/actions/graphql/helpUrls.ts"],"sourcesContent":["export const SCHEMA_LIFT_ANONYMOUS_OBJECT_TYPE = 'schema-lift-anonymous-object-type'\n"],"names":["SCHEMA_LIFT_ANONYMOUS_OBJECT_TYPE"],"mappings":"AAAA,OAAO,MAAMA,oCAAoC,oCAAmC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function isUnion(type) {
|
|
2
|
+
return type.kind === 'Union';
|
|
3
|
+
}
|
|
4
|
+
export function isNonUnion(type) {
|
|
5
|
+
return !isUnion(type) && 'type' in type;
|
|
6
|
+
}
|
|
7
|
+
export function isDocumentType(type) {
|
|
8
|
+
return isNonUnion(type) && type.type === 'Object' && Array.isArray(type.interfaces) && type.interfaces.includes('Document');
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=helpers.js.map
|