import { PackageJsonWithMaybeDeps, JsPackageManager as JsPackageManager$1, PackageJson } from 'storybook/internal/common'; import { SupportedFrameworks, SupportedRenderers, PackageJson as PackageJson$1 } from 'storybook/internal/types'; import * as semver from 'semver'; import { Buffer } from 'node:buffer'; import { ChildProcess } from 'node:child_process'; import { Readable, Writable, Stream } from 'node:stream'; /** A list of all frameworks that are supported, but use a package outside the storybook monorepo */ type ExternalFramework = { name: SupportedFrameworks; packageName?: string; frameworks?: string[]; renderer?: string; }; declare const externalFrameworks: ExternalFramework[]; declare const SUPPORTED_RENDERERS: SupportedRenderers[]; declare enum ProjectType { UNDETECTED = "UNDETECTED", UNSUPPORTED = "UNSUPPORTED", REACT = "REACT", REACT_SCRIPTS = "REACT_SCRIPTS", REACT_NATIVE = "REACT_NATIVE", REACT_NATIVE_WEB = "REACT_NATIVE_WEB", REACT_NATIVE_AND_RNW = "REACT_NATIVE_AND_RNW", REACT_PROJECT = "REACT_PROJECT", WEBPACK_REACT = "WEBPACK_REACT", NEXTJS = "NEXTJS", VUE3 = "VUE3", NUXT = "NUXT", ANGULAR = "ANGULAR", EMBER = "EMBER", WEB_COMPONENTS = "WEB_COMPONENTS", HTML = "HTML", QWIK = "QWIK", PREACT = "PREACT", SVELTE = "SVELTE", SVELTEKIT = "SVELTEKIT", SERVER = "SERVER", NX = "NX", SOLID = "SOLID" } declare enum CoreBuilder { Webpack5 = "webpack5", Vite = "vite" } declare enum CoreWebpackCompilers { Babel = "babel", SWC = "swc" } declare enum CommunityBuilder { Rsbuild = "rsbuild" } declare const compilerNameToCoreCompiler: Record; declare const builderNameToCoreBuilder: Record; type Builder = CoreBuilder | (string & {}); declare enum SupportedLanguage { JAVASCRIPT = "javascript", TYPESCRIPT = "typescript" } type TemplateMatcher = { files?: boolean[]; dependencies?: boolean[]; peerDependencies?: boolean[]; }; type TemplateConfiguration = { preset: ProjectType; /** Will be checked both against dependencies and devDependencies */ dependencies?: string[] | { [dependency: string]: (version: string) => boolean; }; peerDependencies?: string[] | { [dependency: string]: (version: string) => boolean; }; files?: string[]; matcherFunction: (matcher: TemplateMatcher) => boolean; }; /** * Configuration to match a storybook preset template. * * This has to be an array sorted in order of specificity/priority. Reason: both REACT and * WEBPACK_REACT have react as dependency, therefore WEBPACK_REACT has to come first, as it's more * specific. */ declare const supportedTemplates: TemplateConfiguration[]; declare const unsupportedTemplate: TemplateConfiguration; declare const installableProjectTypes: string[]; declare function detectFrameworkPreset(packageJson?: PackageJsonWithMaybeDeps): ProjectType | null; /** * Attempts to detect which builder to use, by searching for a vite config file or webpack * installation. If neither are found it will choose the default builder based on the project type. * * @returns CoreBuilder */ declare function detectBuilder(packageManager: JsPackageManager$1, projectType: ProjectType): Promise; declare function isStorybookInstantiated(configDir?: string): boolean; declare function detectPnp(): Promise; declare function detectLanguage(packageManager: JsPackageManager$1): Promise; declare function detect(packageManager: JsPackageManager$1, options?: { force?: boolean; html?: boolean; }): Promise; declare function readFileAsJson(jsonPath: string, allowComments?: boolean): any; declare const writeFileAsJson: (jsonPath: string, content: unknown) => boolean; /** * Detect if any babel dependencies need to be added to the project This is currently used by * react-native generator * * @example * * ```ts * const babelDependencies = await getBabelDependencies( * packageManager, * npmOptions, * packageJson * ); // you can then spread the result when using installDependencies * installDependencies(npmOptions, [ * `@storybook/react@${storybookVersion}`, * ...babelDependencies, * ]); * ``` * * @param packageJson The current package.json so we can inspect its contents * @returns Contains the packages and versions that need to be installed */ declare function getBabelDependencies(packageManager: JsPackageManager$1): Promise; declare function addToDevDependenciesIfNotPresent(packageJson: PackageJson, name: string, packageVersion: string): void; declare function copyTemplate(templateRoot: string, destination?: string): void; type CopyTemplateFilesOptions = { packageManager: JsPackageManager$1; templateLocation: SupportedFrameworks | SupportedRenderers; language: SupportedLanguage; commonAssetsDir?: string; destination?: string; features: string[]; }; declare const frameworkToDefaultBuilder: Record; /** * Return the installed version of a package, or the coerced version specifier from package.json if * it's a dependency but not installed (e.g. in a fresh project) */ declare function getVersionSafe(packageManager: JsPackageManager$1, packageName: string): Promise; declare const cliStoriesTargetPath: () => Promise<"./src/stories" | "./stories">; declare function copyTemplateFiles({ packageManager, templateLocation, language, destination, commonAssetsDir, features, }: CopyTemplateFilesOptions): Promise; declare function adjustTemplate(templatePath: string, templateData: Record): Promise; declare function isNxProject(): Promise; declare function coerceSemver(version: string): semver.SemVer; declare function hasStorybookDependencies(packageManager: JsPackageManager$1): boolean; declare const ANGULAR_JSON_PATH = "angular.json"; declare const compoDocPreviewPrefix: string; declare const promptForCompoDocs: () => Promise; declare class AngularJSON { json: { projects: Record; }>; }; constructor(); get projects(): Record; }>; get projectsWithoutStorybook(): string[]; get hasStorybookBuilder(): boolean; get rootProject(): { root: string; projectType: string; architect: Record; } | null; getProjectSettingsByName(projectName: string): { root: string; projectType: string; architect: Record; }; getProjectName(): Promise; addStorybookEntries({ angularProjectName, storybookFolder, useCompodoc, root, }: { angularProjectName: string; storybookFolder: string; useCompodoc: boolean; root: string; }): void; write(): void; } declare function getRendererDir(packageManager: JsPackageManager$1, renderer: SupportedFrameworks | SupportedRenderers): Promise; type StdioOption = | 'pipe' | 'overlapped' | 'ipc' | 'ignore' | 'inherit' | Stream | number | undefined; type EncodingOption = | 'utf8' // eslint-disable-next-line unicorn/text-encoding-identifier-case | 'utf-8' | 'utf16le' | 'utf-16le' | 'ucs2' | 'ucs-2' | 'latin1' | 'binary' | 'ascii' | 'hex' | 'base64' | 'base64url' | 'buffer' | null | undefined; type DefaultEncodingOption = 'utf8'; type CommonOptions = { /** Kill the spawned process when the parent process exits unless either: - the spawned process is [`detached`](https://nodejs.org/api/child_process.html#child_process_options_detached) - the parent process is terminated abruptly, for example, with `SIGKILL` as opposed to `SIGTERM` or a normal exit @default true */ readonly cleanup?: boolean; /** Prefer locally installed binaries when looking for a binary to execute. If you `$ npm install foo`, you can then `execa('foo')`. @default `true` with `$`, `false` otherwise */ readonly preferLocal?: boolean; /** Preferred path to find locally installed binaries in (use with `preferLocal`). @default process.cwd() */ readonly localDir?: string | URL; /** Path to the Node.js executable to use in child processes. This can be either an absolute path or a path relative to the `cwd` option. Requires `preferLocal` to be `true`. For example, this can be used together with [`get-node`](https://github.com/ehmicky/get-node) to run a specific Node.js version in a child process. @default process.execPath */ readonly execPath?: string; /** Buffer the output from the spawned process. When set to `false`, you must read the output of `stdout` and `stderr` (or `all` if the `all` option is `true`). Otherwise the returned promise will not be resolved/rejected. If the spawned process fails, `error.stdout`, `error.stderr`, and `error.all` will contain the buffered data. @default true */ readonly buffer?: boolean; /** Same options as [`stdio`](https://nodejs.org/dist/latest-v6.x/docs/api/child_process.html#child_process_options_stdio). @default `inherit` with `$`, `pipe` otherwise */ readonly stdin?: StdioOption; /** Same options as [`stdio`](https://nodejs.org/dist/latest-v6.x/docs/api/child_process.html#child_process_options_stdio). @default 'pipe' */ readonly stdout?: StdioOption; /** Same options as [`stdio`](https://nodejs.org/dist/latest-v6.x/docs/api/child_process.html#child_process_options_stdio). @default 'pipe' */ readonly stderr?: StdioOption; /** Setting this to `false` resolves the promise with the error instead of rejecting it. @default true */ readonly reject?: boolean; /** Add an `.all` property on the promise and the resolved value. The property contains the output of the process with `stdout` and `stderr` interleaved. @default false */ readonly all?: boolean; /** Strip the final [newline character](https://en.wikipedia.org/wiki/Newline) from the output. @default true */ readonly stripFinalNewline?: boolean; /** Set to `false` if you don't want to extend the environment variables when providing the `env` property. @default true */ readonly extendEnv?: boolean; /** Current working directory of the child process. @default process.cwd() */ readonly cwd?: string | URL; /** Environment key-value pairs. Extends automatically from `process.env`. Set `extendEnv` to `false` if you don't want this. @default process.env */ readonly env?: NodeJS.ProcessEnv; /** Explicitly set the value of `argv[0]` sent to the child process. This will be set to `command` or `file` if not specified. */ readonly argv0?: string; /** Child's [stdio](https://nodejs.org/api/child_process.html#child_process_options_stdio) configuration. @default 'pipe' */ readonly stdio?: 'pipe' | 'overlapped' | 'ignore' | 'inherit' | readonly StdioOption[]; /** Specify the kind of serialization used for sending messages between processes when using the `stdio: 'ipc'` option or `execaNode()`: - `json`: Uses `JSON.stringify()` and `JSON.parse()`. - `advanced`: Uses [`v8.serialize()`](https://nodejs.org/api/v8.html#v8_v8_serialize_value) [More info.](https://nodejs.org/api/child_process.html#child_process_advanced_serialization) @default 'json' */ readonly serialization?: 'json' | 'advanced'; /** Prepare child to run independently of its parent process. Specific behavior [depends on the platform](https://nodejs.org/api/child_process.html#child_process_options_detached). @default false */ readonly detached?: boolean; /** Sets the user identity of the process. */ readonly uid?: number; /** Sets the group identity of the process. */ readonly gid?: number; /** If `true`, runs `command` inside of a shell. Uses `/bin/sh` on UNIX and `cmd.exe` on Windows. A different shell can be specified as a string. The shell should understand the `-c` switch on UNIX or `/d /s /c` on Windows. We recommend against using this option since it is: - not cross-platform, encouraging shell-specific syntax. - slower, because of the additional shell interpretation. - unsafe, potentially allowing command injection. @default false */ readonly shell?: boolean | string; /** Specify the character encoding used to decode the `stdout` and `stderr` output. If set to `'buffer'` or `null`, then `stdout` and `stderr` will be a `Buffer` instead of a string. @default 'utf8' */ readonly encoding?: EncodingType; /** If `timeout` is greater than `0`, the parent will send the signal identified by the `killSignal` property (the default is `SIGTERM`) if the child runs longer than `timeout` milliseconds. @default 0 */ readonly timeout?: number; /** Largest amount of data in bytes allowed on `stdout` or `stderr`. Default: 100 MB. @default 100_000_000 */ readonly maxBuffer?: number; /** Signal value to be used when the spawned process will be killed. @default 'SIGTERM' */ readonly killSignal?: string | number; /** You can abort the spawned process using [`AbortController`](https://developer.mozilla.org/en-US/docs/Web/API/AbortController). When `AbortController.abort()` is called, [`.isCanceled`](https://github.com/sindresorhus/execa#iscanceled) becomes `true`. @example ``` import {execa} from 'execa'; const abortController = new AbortController(); const subprocess = execa('node', [], {signal: abortController.signal}); setTimeout(() => { abortController.abort(); }, 1000); try { await subprocess; } catch (error) { console.log(subprocess.killed); // true console.log(error.isCanceled); // true } ``` */ readonly signal?: AbortSignal; /** If `true`, no quoting or escaping of arguments is done on Windows. Ignored on other platforms. This is set to `true` automatically when the `shell` option is `true`. @default false */ readonly windowsVerbatimArguments?: boolean; /** On Windows, do not create a new console window. Please note this also prevents `CTRL-C` [from working](https://github.com/nodejs/node/issues/29837) on Windows. @default true */ readonly windowsHide?: boolean; /** Print each command on `stderr` before executing it. This can also be enabled by setting the `NODE_DEBUG=execa` environment variable in the current process. @default false */ readonly verbose?: boolean; }; type StdoutStderrAll = string | Buffer | undefined; type ExecaReturnBase = { /** The file and arguments that were run, for logging purposes. This is not escaped and should not be executed directly as a process, including using `execa()` or `execaCommand()`. */ command: string; /** Same as `command` but escaped. This is meant to be copy and pasted into a shell, for debugging purposes. Since the escaping is fairly basic, this should not be executed directly as a process, including using `execa()` or `execaCommand()`. */ escapedCommand: string; /** The numeric exit code of the process that was run. */ exitCode: number; /** The output of the process on stdout. */ stdout: StdoutStderrType; /** The output of the process on stderr. */ stderr: StdoutStderrType; /** Whether the process failed to run. */ failed: boolean; /** Whether the process timed out. */ timedOut: boolean; /** Whether the process was killed. */ killed: boolean; /** The name of the signal that was used to terminate the process. For example, `SIGFPE`. If a signal terminated the process, this property is defined and included in the error message. Otherwise it is `undefined`. */ signal?: string; /** A human-friendly description of the signal that was used to terminate the process. For example, `Floating point arithmetic error`. If a signal terminated the process, this property is defined and included in the error message. Otherwise it is `undefined`. It is also `undefined` when the signal is very uncommon which should seldomly happen. */ signalDescription?: string; /** The `cwd` of the command if provided in the command options. Otherwise it is `process.cwd()`. */ cwd: string; }; type ExecaSyncReturnValue = { } & ExecaReturnBase; /** Result of a child process execution. On success this is a plain object. On failure this is also an `Error` instance. The child process fails when: - its exit code is not `0` - it was killed with a signal - timing out - being canceled - there's not enough memory or there are already too many child processes */ type ExecaReturnValue = { /** The output of the process with `stdout` and `stderr` interleaved. This is `undefined` if either: - the `all` option is `false` (default value) - `execaSync()` was used */ all?: StdoutStderrType; /** Whether the process was canceled. You can cancel the spawned process using the [`signal`](https://github.com/sindresorhus/execa#signal-1) option. */ isCanceled: boolean; } & ExecaSyncReturnValue; type ExecaSyncError = { /** Error message when the child process failed to run. In addition to the underlying error message, it also contains some information related to why the child process errored. The child process stderr then stdout are appended to the end, separated with newlines and not interleaved. */ message: string; /** This is the same as the `message` property except it does not include the child process stdout/stderr. */ shortMessage: string; /** Original error message. This is the same as the `message` property except it includes neither the child process stdout/stderr nor some additional information added by Execa. This is `undefined` unless the child process exited due to an `error` event or a timeout. */ originalMessage?: string; } & Error & ExecaReturnBase; type ExecaError = { /** The output of the process with `stdout` and `stderr` interleaved. This is `undefined` if either: - the `all` option is `false` (default value) - `execaSync()` was used */ all?: StdoutStderrType; /** Whether the process was canceled. */ isCanceled: boolean; } & ExecaSyncError; type KillOptions = { /** Milliseconds to wait for the child process to terminate before sending `SIGKILL`. Can be disabled with `false`. @default 5000 */ forceKillAfterTimeout?: number | false; }; type ExecaChildPromise = { /** Stream combining/interleaving [`stdout`](https://nodejs.org/api/child_process.html#child_process_subprocess_stdout) and [`stderr`](https://nodejs.org/api/child_process.html#child_process_subprocess_stderr). This is `undefined` if either: - the `all` option is `false` (the default value) - both `stdout` and `stderr` options are set to [`'inherit'`, `'ipc'`, `Stream` or `integer`](https://nodejs.org/dist/latest-v6.x/docs/api/child_process.html#child_process_options_stdio) */ all?: Readable; catch( onRejected?: (reason: ExecaError) => ResultType | PromiseLike ): Promise | ResultType>; /** Same as the original [`child_process#kill()`](https://nodejs.org/api/child_process.html#child_process_subprocess_kill_signal), except if `signal` is `SIGTERM` (the default value) and the child process is not terminated after 5 seconds, force it by sending `SIGKILL`. Note that this graceful termination does not work on Windows, because Windows [doesn't support signals](https://nodejs.org/api/process.html#process_signal_events) (`SIGKILL` and `SIGTERM` has the same effect of force-killing the process immediately.) If you want to achieve graceful termination on Windows, you have to use other means, such as [`taskkill`](https://github.com/sindresorhus/taskkill). */ kill(signal?: string, options?: KillOptions): void; /** Similar to [`childProcess.kill()`](https://nodejs.org/api/child_process.html#child_process_subprocess_kill_signal). This used to be preferred when cancelling the child process execution as the error is more descriptive and [`childProcessResult.isCanceled`](#iscanceled) is set to `true`. But now this is deprecated and you should either use `.kill()` or the `signal` option when creating the child process. */ cancel(): void; /** [Pipe](https://nodejs.org/api/stream.html#readablepipedestination-options) the child process's `stdout` to `target`, which can be: - Another `execa()` return value - A writable stream - A file path string If the `target` is another `execa()` return value, it is returned. Otherwise, the original `execa()` return value is returned. This allows chaining `pipeStdout()` then `await`ing the final result. The `stdout` option] must be kept as `pipe`, its default value. */ pipeStdout?>(target: Target): Target; pipeStdout?(target: Writable | string): ExecaChildProcess; /** Like `pipeStdout()` but piping the child process's `stderr` instead. The `stderr` option must be kept as `pipe`, its default value. */ pipeStderr?>(target: Target): Target; pipeStderr?(target: Writable | string): ExecaChildProcess; /** Combines both `pipeStdout()` and `pipeStderr()`. Either the `stdout` option or the `stderr` option must be kept as `pipe`, their default value. Also, the `all` option must be set to `true`. */ pipeAll?>(target: Target): Target; pipeAll?(target: Writable | string): ExecaChildProcess; }; type ExecaChildProcess = ChildProcess & ExecaChildPromise & Promise>; type PackageJsonWithDepsAndDevDeps = PackageJson$1 & Required>; type PackageMetadata = { version: string; location?: string; reasons?: string[]; }; type InstallationMetadata = { dependencies: Record; duplicatedDependencies: Record; infoCommand: string; dedupeCommand: string; }; type PackageManagerName = 'npm' | 'yarn1' | 'yarn2' | 'pnpm' | 'bun'; interface JsPackageManagerOptions { cwd?: string; configDir?: string; storiesPaths?: string[]; } type PackageJsonInfo = { packageJsonPath: string; operationDir: string; packageJson: PackageJsonWithDepsAndDevDeps; }; declare abstract class JsPackageManager { #private; abstract readonly type: PackageManagerName; /** The path to the primary package.json file (contains the `storybook` dependency). */ readonly primaryPackageJson: PackageJsonInfo; /** The paths to all package.json files in the project root. */ packageJsonPaths: string[]; /** * The path to the Storybook instance directory. This is used to find the primary package.json * file in a repository. */ readonly instanceDir: string; /** The current working directory. */ protected readonly cwd: string; /** Cache for latest version results to avoid repeated network calls. */ static readonly latestVersionCache: Map; /** Cache for installed version results to avoid repeated file system calls. */ static readonly installedVersionCache: Map; constructor(options?: JsPackageManagerOptions); /** Runs arbitrary package scripts. */ abstract getRunCommand(command: string): string; /** * Run a command from a local or remote. Fetches a package from the registry without installing it * as a dependency, hotloads it, and runs whatever default command binary it exposes. */ abstract getRemoteRunCommand(pkg: string, args: string[], specifier?: string): string; /** Get the package.json file for a given module. */ abstract getModulePackageJSON(packageName: string): PackageJson$1 | null; isStorybookInMonorepo(): boolean; installDependencies(options?: { force?: boolean; }): Promise; dedupeDependencies(options?: { force?: boolean; }): Promise; /** Read the `package.json` file available in the provided directory */ static getPackageJson(packageJsonPath: string): PackageJsonWithDepsAndDevDeps; writePackageJson(packageJson: PackageJson$1, directory?: string): void; getAllDependencies(): Record; isDependencyInstalled(dependency: string): boolean; /** * Add dependencies to a project using `yarn add` or `npm install`. * * @example * * ```ts * addDependencies(options, [ * `@storybook/react@${storybookVersion}`, * `@storybook/addon-links@${linksVersion}`, * ]); * ``` * * @param {Object} options Contains `skipInstall`, `packageJson` and `installAsDevDependencies` * which we use to determine how we install packages. * @param {Array} dependencies Contains a list of packages to add. */ addDependencies(options: { skipInstall: true; type: 'dependencies' | 'devDependencies' | 'peerDependencies'; writeOutputToFile?: boolean; packageJsonInfo?: PackageJsonInfo; } | { skipInstall?: false; type: 'dependencies' | 'devDependencies'; writeOutputToFile?: boolean; packageJsonInfo?: PackageJsonInfo; }, dependencies: string[]): Promise; /** * Removing dependencies from the package.json file, which is found first starting from the * instance root. The method does not run a package manager install like `npm install`. * * @example * * ```ts * removeDependencies([`@storybook/react`]); * ``` * * @param dependencies Contains a list of packages to remove. */ removeDependencies(dependencies: string[]): Promise; /** * Return an array of strings matching following format: `@` * * For packages in the storybook monorepo, when the latest version is equal to the version of the * current CLI the version is not added to the string. * * When a package is in the monorepo, and the version is not equal to the CLI version, the version * is taken from the versions.ts file and added to the string. * * @param packages */ getVersionedPackages(packages: string[]): Promise; /** * Return an array of string standing for the latest version of the input packages. To be able to * identify which version goes with which package the order of the input array is keep. * * @param packageNames */ getVersions(...packageNames: string[]): Promise; /** * Return the latest version of the input package available on npmjs registry. If constraint are * provided it return the latest version matching the constraints. * * For `@storybook/*` packages the latest version is retrieved from `cli/src/versions.json` file * directly * * @param packageName The name of the package * @param constraint A valid semver constraint, example: '1.x || >=2.5.0 || 5.0.0 - 7.2.3' */ getVersion(packageName: string, constraint?: string): Promise; /** * Get the latest version of the package available on npmjs.com. If constraint is set then it * returns a version satisfying it, otherwise the latest version available is returned. * * @param packageName Name of the package * @param constraint Version range to use to constraint the returned version */ latestVersion(packageName: string, constraint?: string): Promise; /** * Clear the latest version cache. Useful for testing or when you want to refresh version * information. * * @param packageName Optional package name to clear only specific entries. If not provided, * clears all cache. */ static clearLatestVersionCache(packageName?: string): void; /** * Clear the installed version cache for a specific package or all packages. * * @param packageName Optional package name to clear from cache. If not provided, clears all. */ clearInstalledVersionCache(packageName?: string): void; /** * Clear both the latest version cache and installed version cache. This should be called after * any operation that modifies dependencies. */ clearAllVersionCaches(): void; addStorybookCommandInScripts(options?: { port: number; preCommand?: string; }): void; addScripts(scripts: Record): void; addPackageResolutions(versions: Record): void; protected abstract runInstall(options?: { force?: boolean; }): ExecaChildProcess; protected abstract runAddDeps(dependencies: string[], installAsDevDependencies: boolean, writeOutputToFile?: boolean): ExecaChildProcess; protected abstract getResolutions(packageJson: PackageJson$1, versions: Record): Record; /** * Get the latest or all versions of the input package available on npmjs.com * * @param packageName Name of the package * @param fetchAllVersions Should return */ protected abstract runGetVersions(packageName: string, fetchAllVersions: T): Promise; abstract getRegistryURL(): Promise; abstract runInternalCommand(command: string, args: string[], cwd?: string, stdio?: 'inherit' | 'pipe' | 'ignore'): ExecaChildProcess; abstract runPackageCommand(command: string, args: string[], cwd?: string, stdio?: 'inherit' | 'pipe' | 'ignore'): ExecaChildProcess; abstract runPackageCommandSync(command: string, args: string[], cwd?: string, stdio?: 'inherit' | 'pipe' | 'ignore'): string; abstract findInstallations(pattern?: string[]): Promise; abstract findInstallations(pattern?: string[], options?: { depth: number; }): Promise; abstract parseErrorFromLogs(logs?: string): string; executeCommandSync({ command, args, stdio, cwd, ignoreError, env, ...execaOptions }: CommonOptions<'utf8'> & { command: string; args: string[]; cwd?: string; ignoreError?: boolean; }): string; /** * Execute a command asynchronously and return the execa process. This allows you to hook into * stdout/stderr streams and monitor the process. * * @example Const process = packageManager.executeCommand({ command: 'npm', args: ['install'] }); * process.stdout?.on('data', (data) => console.log(data.toString())); const result = await * process; */ executeCommand({ command, args, stdio, cwd, ignoreError, env, ...execaOptions }: CommonOptions<'utf8'> & { command: string; args: string[]; cwd?: string; ignoreError?: boolean; }): ExecaChildProcess; /** Returns the installed (within node_modules or pnp zip) version of a specified package */ getInstalledVersion(packageName: string): Promise; isPackageInstalled(packageName: string): Promise; /** * Searches for a dependency/devDependency in all package.json files and returns the version of * the dependency. */ getDependencyVersion(dependency: string): string | null; static hasStorybookDependency(packageJsonPath: string): boolean; static hasAnyStorybookDependency(packageJsonPath: string): boolean; /** List all package.json files starting from the given directory and stopping at the project root. */ static listAllPackageJsonPaths(instanceDir: string, storiesPaths?: string[]): string[]; static getPackageJsonInfo(packageJsonPath: string): PackageJsonInfo; } type NpmOptions = Parameters[0]; declare const SUPPORTED_ESLINT_EXTENSIONS: string[]; declare const findEslintFile: (instanceDir: string) => Promise; declare const configureFlatConfig: (code: string) => Promise; declare function extractEslintInfo(packageManager: JsPackageManager$1): Promise<{ hasEslint: boolean; isStorybookPluginInstalled: boolean; eslintConfigFile: string | undefined; unsupportedExtension?: string; isFlatConfig: boolean; }>; declare const normalizeExtends: (existingExtends: any) => string[]; declare function configureEslintPlugin({ eslintConfigFile, packageManager, isFlatConfig, }: { eslintConfigFile: string | undefined; packageManager: JsPackageManager$1; isFlatConfig: boolean; }): Promise; declare const suggestESLintPlugin: () => Promise; type Primitive = string | number | symbol | bigint | boolean | null | undefined; declare namespace util { type AssertEqual = (() => V extends T ? 1 : 2) extends () => V extends U ? 1 : 2 ? true : false; export type isAny = 0 extends 1 & T ? true : false; export const assertEqual: (val: AssertEqual) => AssertEqual; export function assertIs(_arg: T): void; export function assertNever(_x: never): never; export type Omit = Pick>; export type OmitKeys = Pick>; export type MakePartial = Omit & Partial>; export type Exactly = T & Record, never>; export const arrayToEnum: (items: U) => { [k in U[number]]: k; }; export const getValidEnumValues: (obj: any) => any[]; export const objectValues: (obj: any) => any[]; export const objectKeys: ObjectConstructor["keys"]; export const find: (arr: T[], checker: (arg: T) => any) => T | undefined; export type identity = objectUtil.identity; export type flatten = objectUtil.flatten; export type noUndefined = T extends undefined ? never : T; export const isInteger: NumberConstructor["isInteger"]; export function joinValues(array: T, separator?: string): string; export const jsonStringifyReplacer: (_: string, value: any) => any; export { }; } declare namespace objectUtil { export type MergeShapes = keyof U & keyof V extends never ? U & V : { [k in Exclude]: U[k]; } & V; type optionalKeys = { [k in keyof T]: undefined extends T[k] ? k : never; }[keyof T]; type requiredKeys = { [k in keyof T]: undefined extends T[k] ? never : k; }[keyof T]; export type addQuestionMarks = { [K in requiredKeys]: T[K]; } & { [K in optionalKeys]?: T[K]; } & { [k in keyof T]?: unknown; }; export type identity = T; export type flatten = identity<{ [k in keyof T]: T[k]; }>; export type noNeverKeys = { [k in keyof T]: [T[k]] extends [never] ? never : k; }[keyof T]; export type noNever = identity<{ [k in noNeverKeys]: k extends keyof T ? T[k] : never; }>; export const mergeShapes: (first: U, second: T) => T & U; export type extendShape = keyof A & keyof B extends never ? A & B : { [K in keyof A as K extends keyof B ? never : K]: A[K]; } & { [K in keyof B]: B[K]; }; export { }; } declare const ZodParsedType: { string: "string"; number: "number"; bigint: "bigint"; boolean: "boolean"; symbol: "symbol"; undefined: "undefined"; object: "object"; function: "function"; map: "map"; nan: "nan"; integer: "integer"; float: "float"; date: "date"; null: "null"; array: "array"; unknown: "unknown"; promise: "promise"; void: "void"; never: "never"; set: "set"; }; type ZodParsedType = keyof typeof ZodParsedType; type allKeys = T extends any ? keyof T : never; type typeToFlattenedError = { formErrors: U[]; fieldErrors: { [P in allKeys]?: U[]; }; }; declare const ZodIssueCode: { invalid_type: "invalid_type"; invalid_literal: "invalid_literal"; custom: "custom"; invalid_union: "invalid_union"; invalid_union_discriminator: "invalid_union_discriminator"; invalid_enum_value: "invalid_enum_value"; unrecognized_keys: "unrecognized_keys"; invalid_arguments: "invalid_arguments"; invalid_return_type: "invalid_return_type"; invalid_date: "invalid_date"; invalid_string: "invalid_string"; too_small: "too_small"; too_big: "too_big"; invalid_intersection_types: "invalid_intersection_types"; not_multiple_of: "not_multiple_of"; not_finite: "not_finite"; }; type ZodIssueCode = keyof typeof ZodIssueCode; type ZodIssueBase = { path: (string | number)[]; message?: string; }; interface ZodInvalidTypeIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_type; expected: ZodParsedType; received: ZodParsedType; } interface ZodInvalidLiteralIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_literal; expected: unknown; received: unknown; } interface ZodUnrecognizedKeysIssue extends ZodIssueBase { code: typeof ZodIssueCode.unrecognized_keys; keys: string[]; } interface ZodInvalidUnionIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_union; unionErrors: ZodError[]; } interface ZodInvalidUnionDiscriminatorIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_union_discriminator; options: Primitive[]; } interface ZodInvalidEnumValueIssue extends ZodIssueBase { received: string | number; code: typeof ZodIssueCode.invalid_enum_value; options: (string | number)[]; } interface ZodInvalidArgumentsIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_arguments; argumentsError: ZodError; } interface ZodInvalidReturnTypeIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_return_type; returnTypeError: ZodError; } interface ZodInvalidDateIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_date; } type StringValidation = "email" | "url" | "emoji" | "uuid" | "nanoid" | "regex" | "cuid" | "cuid2" | "ulid" | "datetime" | "date" | "time" | "duration" | "ip" | "cidr" | "base64" | "jwt" | "base64url" | { includes: string; position?: number; } | { startsWith: string; } | { endsWith: string; }; interface ZodInvalidStringIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_string; validation: StringValidation; } interface ZodTooSmallIssue extends ZodIssueBase { code: typeof ZodIssueCode.too_small; minimum: number | bigint; inclusive: boolean; exact?: boolean; type: "array" | "string" | "number" | "set" | "date" | "bigint"; } interface ZodTooBigIssue extends ZodIssueBase { code: typeof ZodIssueCode.too_big; maximum: number | bigint; inclusive: boolean; exact?: boolean; type: "array" | "string" | "number" | "set" | "date" | "bigint"; } interface ZodInvalidIntersectionTypesIssue extends ZodIssueBase { code: typeof ZodIssueCode.invalid_intersection_types; } interface ZodNotMultipleOfIssue extends ZodIssueBase { code: typeof ZodIssueCode.not_multiple_of; multipleOf: number | bigint; } interface ZodNotFiniteIssue extends ZodIssueBase { code: typeof ZodIssueCode.not_finite; } interface ZodCustomIssue extends ZodIssueBase { code: typeof ZodIssueCode.custom; params?: { [k: string]: any; }; } type ZodIssueOptionalMessage = ZodInvalidTypeIssue | ZodInvalidLiteralIssue | ZodUnrecognizedKeysIssue | ZodInvalidUnionIssue | ZodInvalidUnionDiscriminatorIssue | ZodInvalidEnumValueIssue | ZodInvalidArgumentsIssue | ZodInvalidReturnTypeIssue | ZodInvalidDateIssue | ZodInvalidStringIssue | ZodTooSmallIssue | ZodTooBigIssue | ZodInvalidIntersectionTypesIssue | ZodNotMultipleOfIssue | ZodNotFiniteIssue | ZodCustomIssue; type ZodIssue = ZodIssueOptionalMessage & { fatal?: boolean; message: string; }; type recursiveZodFormattedError = T extends [any, ...any[]] ? { [K in keyof T]?: ZodFormattedError; } : T extends any[] ? { [k: number]: ZodFormattedError; } : T extends object ? { [K in keyof T]?: ZodFormattedError; } : unknown; type ZodFormattedError = { _errors: U[]; } & recursiveZodFormattedError>; declare class ZodError extends Error { issues: ZodIssue[]; get errors(): ZodIssue[]; constructor(issues: ZodIssue[]); format(): ZodFormattedError; format(mapper: (issue: ZodIssue) => U): ZodFormattedError; static create: (issues: ZodIssue[]) => ZodError; static assert(value: unknown): asserts value is ZodError; toString(): string; get message(): string; get isEmpty(): boolean; addIssue: (sub: ZodIssue) => void; addIssues: (subs?: ZodIssue[]) => void; flatten(): typeToFlattenedError; flatten(mapper?: (issue: ZodIssue) => U): typeToFlattenedError; get formErrors(): typeToFlattenedError; } type stripPath = T extends any ? util.OmitKeys : never; type IssueData = stripPath & { path?: (string | number)[]; fatal?: boolean; }; type ErrorMapCtx = { defaultError: string; data: any; }; type ZodErrorMap = (issue: ZodIssueOptionalMessage, _ctx: ErrorMapCtx) => { message: string; }; type ParseParams = { path: (string | number)[]; errorMap: ZodErrorMap; async: boolean; }; type ParsePathComponent = string | number; type ParsePath = ParsePathComponent[]; interface ParseContext { readonly common: { readonly issues: ZodIssue[]; readonly contextualErrorMap?: ZodErrorMap; readonly async: boolean; }; readonly path: ParsePath; readonly schemaErrorMap?: ZodErrorMap; readonly parent: ParseContext | null; readonly data: any; readonly parsedType: ZodParsedType; } type ParseInput = { data: any; path: (string | number)[]; parent: ParseContext; }; declare class ParseStatus { value: "aborted" | "dirty" | "valid"; dirty(): void; abort(): void; static mergeArray(status: ParseStatus, results: SyncParseReturnType[]): SyncParseReturnType; static mergeObjectAsync(status: ParseStatus, pairs: { key: ParseReturnType; value: ParseReturnType; }[]): Promise>; static mergeObjectSync(status: ParseStatus, pairs: { key: SyncParseReturnType; value: SyncParseReturnType; alwaysSet?: boolean; }[]): SyncParseReturnType; } type INVALID = { status: "aborted"; }; declare const INVALID: INVALID; type DIRTY = { status: "dirty"; value: T; }; declare const DIRTY: (value: T) => DIRTY; type OK = { status: "valid"; value: T; }; declare const OK: (value: T) => OK; type SyncParseReturnType = OK | DIRTY | INVALID; type AsyncParseReturnType = Promise>; type ParseReturnType = SyncParseReturnType | AsyncParseReturnType; declare namespace enumUtil { type UnionToIntersectionFn = (T extends unknown ? (k: () => T) => void : never) extends (k: infer Intersection) => void ? Intersection : never; type GetUnionLast = UnionToIntersectionFn extends () => infer Last ? Last : never; type UnionToTuple = [T] extends [never] ? Tuple : UnionToTuple>, [GetUnionLast, ...Tuple]>; type CastToStringTuple = T extends [string, ...string[]] ? T : never; export type UnionToTupleString = CastToStringTuple>; export { }; } declare namespace errorUtil { type ErrMessage = string | { message?: string; }; const errToObj: (message?: ErrMessage) => { message?: string | undefined; }; const toString: (message?: ErrMessage) => string | undefined; } declare namespace partialUtil { type DeepPartial = T extends ZodObject ? ZodObject<{ [k in keyof T["shape"]]: ZodOptional>; }, T["_def"]["unknownKeys"], T["_def"]["catchall"]> : T extends ZodArray ? ZodArray, Card> : T extends ZodOptional ? ZodOptional> : T extends ZodNullable ? ZodNullable> : T extends ZodTuple ? { [k in keyof Items]: Items[k] extends ZodTypeAny ? DeepPartial : never; } extends infer PI ? PI extends ZodTupleItems ? ZodTuple : never : never : T; } /** * The Standard Schema interface. */ type StandardSchemaV1 = { /** * The Standard Schema properties. */ readonly "~standard": StandardSchemaV1.Props; }; declare namespace StandardSchemaV1 { /** * The Standard Schema properties interface. */ export interface Props { /** * The version number of the standard. */ readonly version: 1; /** * The vendor name of the schema library. */ readonly vendor: string; /** * Validates unknown input values. */ readonly validate: (value: unknown) => Result | Promise>; /** * Inferred types associated with the schema. */ readonly types?: Types | undefined; } /** * The result interface of the validate function. */ export type Result = SuccessResult | FailureResult; /** * The result interface if validation succeeds. */ export interface SuccessResult { /** * The typed output value. */ readonly value: Output; /** * The non-existent issues. */ readonly issues?: undefined; } /** * The result interface if validation fails. */ export interface FailureResult { /** * The issues of failed validation. */ readonly issues: ReadonlyArray; } /** * The issue interface of the failure output. */ export interface Issue { /** * The error message of the issue. */ readonly message: string; /** * The path of the issue, if any. */ readonly path?: ReadonlyArray | undefined; } /** * The path segment interface of the issue. */ export interface PathSegment { /** * The key representing a path segment. */ readonly key: PropertyKey; } /** * The Standard Schema types interface. */ export interface Types { /** * The input type of the schema. */ readonly input: Input; /** * The output type of the schema. */ readonly output: Output; } /** * Infers the input type of a Standard Schema. */ export type InferInput = NonNullable["input"]; /** * Infers the output type of a Standard Schema. */ export type InferOutput = NonNullable["output"]; export { }; } interface RefinementCtx { addIssue: (arg: IssueData) => void; path: (string | number)[]; } type ZodRawShape = { [k: string]: ZodTypeAny; }; type ZodTypeAny = ZodType; type TypeOf> = T["_output"]; type input> = T["_input"]; type output> = T["_output"]; type CustomErrorParams = Partial>; interface ZodTypeDef { errorMap?: ZodErrorMap; description?: string; } type RawCreateParams = { errorMap?: ZodErrorMap; invalid_type_error?: string; required_error?: string; message?: string; description?: string; } | undefined; type SafeParseSuccess = { success: true; data: Output; error?: never; }; type SafeParseError = { success: false; error: ZodError; data?: never; }; type SafeParseReturnType = SafeParseSuccess | SafeParseError; declare abstract class ZodType { readonly _type: Output; readonly _output: Output; readonly _input: Input; readonly _def: Def; get description(): string | undefined; "~standard": StandardSchemaV1.Props; abstract _parse(input: ParseInput): ParseReturnType; _getType(input: ParseInput): string; _getOrReturnCtx(input: ParseInput, ctx?: ParseContext | undefined): ParseContext; _processInputParams(input: ParseInput): { status: ParseStatus; ctx: ParseContext; }; _parseSync(input: ParseInput): SyncParseReturnType; _parseAsync(input: ParseInput): AsyncParseReturnType; parse(data: unknown, params?: Partial): Output; safeParse(data: unknown, params?: Partial): SafeParseReturnType; "~validate"(data: unknown): StandardSchemaV1.Result | Promise>; parseAsync(data: unknown, params?: Partial): Promise; safeParseAsync(data: unknown, params?: Partial): Promise>; /** Alias of safeParseAsync */ spa: (data: unknown, params?: Partial) => Promise>; refine(check: (arg: Output) => arg is RefinedOutput, message?: string | CustomErrorParams | ((arg: Output) => CustomErrorParams)): ZodEffects; refine(check: (arg: Output) => unknown | Promise, message?: string | CustomErrorParams | ((arg: Output) => CustomErrorParams)): ZodEffects; refinement(check: (arg: Output) => arg is RefinedOutput, refinementData: IssueData | ((arg: Output, ctx: RefinementCtx) => IssueData)): ZodEffects; refinement(check: (arg: Output) => boolean, refinementData: IssueData | ((arg: Output, ctx: RefinementCtx) => IssueData)): ZodEffects; _refinement(refinement: RefinementEffect["refinement"]): ZodEffects; superRefine(refinement: (arg: Output, ctx: RefinementCtx) => arg is RefinedOutput): ZodEffects; superRefine(refinement: (arg: Output, ctx: RefinementCtx) => void): ZodEffects; superRefine(refinement: (arg: Output, ctx: RefinementCtx) => Promise): ZodEffects; constructor(def: Def); optional(): ZodOptional; nullable(): ZodNullable; nullish(): ZodOptional>; array(): ZodArray; promise(): ZodPromise; or(option: T): ZodUnion<[this, T]>; and(incoming: T): ZodIntersection; transform(transform: (arg: Output, ctx: RefinementCtx) => NewOut | Promise): ZodEffects; default(def: util.noUndefined): ZodDefault; default(def: () => util.noUndefined): ZodDefault; brand(brand?: B): ZodBranded; catch(def: Output): ZodCatch; catch(def: (ctx: { error: ZodError; input: Input; }) => Output): ZodCatch; describe(description: string): this; pipe(target: T): ZodPipeline; readonly(): ZodReadonly; isOptional(): boolean; isNullable(): boolean; } type ZodNumberCheck = { kind: "min"; value: number; inclusive: boolean; message?: string; } | { kind: "max"; value: number; inclusive: boolean; message?: string; } | { kind: "int"; message?: string; } | { kind: "multipleOf"; value: number; message?: string; } | { kind: "finite"; message?: string; }; interface ZodNumberDef extends ZodTypeDef { checks: ZodNumberCheck[]; typeName: ZodFirstPartyTypeKind.ZodNumber; coerce: boolean; } declare class ZodNumber extends ZodType { _parse(input: ParseInput): ParseReturnType; static create: (params?: RawCreateParams & { coerce?: boolean; }) => ZodNumber; gte(value: number, message?: errorUtil.ErrMessage): ZodNumber; min: (value: number, message?: errorUtil.ErrMessage) => ZodNumber; gt(value: number, message?: errorUtil.ErrMessage): ZodNumber; lte(value: number, message?: errorUtil.ErrMessage): ZodNumber; max: (value: number, message?: errorUtil.ErrMessage) => ZodNumber; lt(value: number, message?: errorUtil.ErrMessage): ZodNumber; protected setLimit(kind: "min" | "max", value: number, inclusive: boolean, message?: string): ZodNumber; _addCheck(check: ZodNumberCheck): ZodNumber; int(message?: errorUtil.ErrMessage): ZodNumber; positive(message?: errorUtil.ErrMessage): ZodNumber; negative(message?: errorUtil.ErrMessage): ZodNumber; nonpositive(message?: errorUtil.ErrMessage): ZodNumber; nonnegative(message?: errorUtil.ErrMessage): ZodNumber; multipleOf(value: number, message?: errorUtil.ErrMessage): ZodNumber; step: (value: number, message?: errorUtil.ErrMessage) => ZodNumber; finite(message?: errorUtil.ErrMessage): ZodNumber; safe(message?: errorUtil.ErrMessage): ZodNumber; get minValue(): number | null; get maxValue(): number | null; get isInt(): boolean; get isFinite(): boolean; } interface ZodBooleanDef extends ZodTypeDef { typeName: ZodFirstPartyTypeKind.ZodBoolean; coerce: boolean; } declare class ZodBoolean extends ZodType { _parse(input: ParseInput): ParseReturnType; static create: (params?: RawCreateParams & { coerce?: boolean; }) => ZodBoolean; } interface ZodArrayDef extends ZodTypeDef { type: T; typeName: ZodFirstPartyTypeKind.ZodArray; exactLength: { value: number; message?: string; } | null; minLength: { value: number; message?: string; } | null; maxLength: { value: number; message?: string; } | null; } type ArrayCardinality = "many" | "atleastone"; type arrayOutputType = Cardinality extends "atleastone" ? [T["_output"], ...T["_output"][]] : T["_output"][]; declare class ZodArray extends ZodType, ZodArrayDef, Cardinality extends "atleastone" ? [T["_input"], ...T["_input"][]] : T["_input"][]> { _parse(input: ParseInput): ParseReturnType; get element(): T; min(minLength: number, message?: errorUtil.ErrMessage): this; max(maxLength: number, message?: errorUtil.ErrMessage): this; length(len: number, message?: errorUtil.ErrMessage): this; nonempty(message?: errorUtil.ErrMessage): ZodArray; static create: (schema: T_1, params?: RawCreateParams) => ZodArray; } type UnknownKeysParam = "passthrough" | "strict" | "strip"; interface ZodObjectDef extends ZodTypeDef { typeName: ZodFirstPartyTypeKind.ZodObject; shape: () => T; catchall: Catchall; unknownKeys: UnknownKeys; } type objectOutputType = objectUtil.flatten>> & CatchallOutput & PassthroughType; type baseObjectOutputType = { [k in keyof Shape]: Shape[k]["_output"]; }; type objectInputType = objectUtil.flatten> & CatchallInput & PassthroughType; type baseObjectInputType = objectUtil.addQuestionMarks<{ [k in keyof Shape]: Shape[k]["_input"]; }>; type CatchallOutput = ZodType extends T ? unknown : { [k: string]: T["_output"]; }; type CatchallInput = ZodType extends T ? unknown : { [k: string]: T["_input"]; }; type PassthroughType = T extends "passthrough" ? { [k: string]: unknown; } : unknown; type deoptional = T extends ZodOptional ? deoptional : T extends ZodNullable ? ZodNullable> : T; declare class ZodObject, Input = objectInputType> extends ZodType, Input> { private _cached; _getCached(): { shape: T; keys: string[]; }; _parse(input: ParseInput): ParseReturnType; get shape(): T; strict(message?: errorUtil.ErrMessage): ZodObject; strip(): ZodObject; passthrough(): ZodObject; /** * @deprecated In most cases, this is no longer needed - unknown properties are now silently stripped. * If you want to pass through unknown properties, use `.passthrough()` instead. */ nonstrict: () => ZodObject; extend(augmentation: Augmentation): ZodObject, UnknownKeys, Catchall>; /** * @deprecated Use `.extend` instead * */ augment: (augmentation: Augmentation) => ZodObject, UnknownKeys, Catchall>; /** * Prior to zod@1.0.12 there was a bug in the * inferred type of merged objects. Please * upgrade if you are experiencing issues. */ merge(merging: Incoming): ZodObject, Incoming["_def"]["unknownKeys"], Incoming["_def"]["catchall"]>; setKey(key: Key, schema: Schema): ZodObject; catchall(index: Index): ZodObject; pick>(mask: Mask): ZodObject>, UnknownKeys, Catchall>; omit>(mask: Mask): ZodObject, UnknownKeys, Catchall>; /** * @deprecated */ deepPartial(): partialUtil.DeepPartial; partial(): ZodObject<{ [k in keyof T]: ZodOptional; }, UnknownKeys, Catchall>; partial>(mask: Mask): ZodObject : T[k]; }>, UnknownKeys, Catchall>; required(): ZodObject<{ [k in keyof T]: deoptional; }, UnknownKeys, Catchall>; required>(mask: Mask): ZodObject : T[k]; }>, UnknownKeys, Catchall>; keyof(): ZodEnum>; static create: (shape: T_1, params?: RawCreateParams) => ZodObject, any> extends infer T_2 ? { [k in keyof T_2]: objectUtil.addQuestionMarks, any>[k]; } : never, baseObjectInputType extends infer T_3 ? { [k_1 in keyof T_3]: baseObjectInputType[k_1]; } : never>; static strictCreate: (shape: T_1, params?: RawCreateParams) => ZodObject, any> extends infer T_2 ? { [k in keyof T_2]: objectUtil.addQuestionMarks, any>[k]; } : never, baseObjectInputType extends infer T_3 ? { [k_1 in keyof T_3]: baseObjectInputType[k_1]; } : never>; static lazycreate: (shape: () => T_1, params?: RawCreateParams) => ZodObject, any> extends infer T_2 ? { [k in keyof T_2]: objectUtil.addQuestionMarks, any>[k]; } : never, baseObjectInputType extends infer T_3 ? { [k_1 in keyof T_3]: baseObjectInputType[k_1]; } : never>; } type AnyZodObject = ZodObject; type ZodUnionOptions = Readonly<[ZodTypeAny, ...ZodTypeAny[]]>; interface ZodUnionDef> extends ZodTypeDef { options: T; typeName: ZodFirstPartyTypeKind.ZodUnion; } declare class ZodUnion extends ZodType, T[number]["_input"]> { _parse(input: ParseInput): ParseReturnType; get options(): T; static create: (types: T_1, params?: RawCreateParams) => ZodUnion; } interface ZodIntersectionDef extends ZodTypeDef { left: T; right: U; typeName: ZodFirstPartyTypeKind.ZodIntersection; } declare class ZodIntersection extends ZodType, T["_input"] & U["_input"]> { _parse(input: ParseInput): ParseReturnType; static create: (left: T_1, right: U_1, params?: RawCreateParams) => ZodIntersection; } type ZodTupleItems = [ZodTypeAny, ...ZodTypeAny[]]; type AssertArray = T extends any[] ? T : never; type OutputTypeOfTuple = AssertArray<{ [k in keyof T]: T[k] extends ZodType ? T[k]["_output"] : never; }>; type OutputTypeOfTupleWithRest = Rest extends ZodTypeAny ? [...OutputTypeOfTuple, ...Rest["_output"][]] : OutputTypeOfTuple; type InputTypeOfTuple = AssertArray<{ [k in keyof T]: T[k] extends ZodType ? T[k]["_input"] : never; }>; type InputTypeOfTupleWithRest = Rest extends ZodTypeAny ? [...InputTypeOfTuple, ...Rest["_input"][]] : InputTypeOfTuple; interface ZodTupleDef extends ZodTypeDef { items: T; rest: Rest; typeName: ZodFirstPartyTypeKind.ZodTuple; } declare class ZodTuple extends ZodType, ZodTupleDef, InputTypeOfTupleWithRest> { _parse(input: ParseInput): ParseReturnType; get items(): T; rest(rest: Rest): ZodTuple; static create: (schemas: T_1, params?: RawCreateParams) => ZodTuple; } type EnumValues = readonly [T, ...T[]]; type Values = { [k in T[number]]: k; }; interface ZodEnumDef extends ZodTypeDef { values: T; typeName: ZodFirstPartyTypeKind.ZodEnum; } type Writeable = { -readonly [P in keyof T]: T[P]; }; type FilterEnum = Values extends [] ? [] : Values extends [infer Head, ...infer Rest] ? Head extends ToExclude ? FilterEnum : [Head, ...FilterEnum] : never; type typecast = A extends T ? A : never; declare function createZodEnum>(values: T, params?: RawCreateParams): ZodEnum>; declare function createZodEnum(values: T, params?: RawCreateParams): ZodEnum; declare class ZodEnum extends ZodType, T[number]> { #private; _parse(input: ParseInput): ParseReturnType; get options(): T; get enum(): Values; get Values(): Values; get Enum(): Values; extract(values: ToExtract, newDef?: RawCreateParams): ZodEnum>; exclude(values: ToExclude, newDef?: RawCreateParams): ZodEnum>, [string, ...string[]]>>; static create: typeof createZodEnum; } interface ZodPromiseDef extends ZodTypeDef { type: T; typeName: ZodFirstPartyTypeKind.ZodPromise; } declare class ZodPromise extends ZodType, ZodPromiseDef, Promise> { unwrap(): T; _parse(input: ParseInput): ParseReturnType; static create: (schema: T_1, params?: RawCreateParams) => ZodPromise; } type RefinementEffect = { type: "refinement"; refinement: (arg: T, ctx: RefinementCtx) => any; }; type TransformEffect = { type: "transform"; transform: (arg: T, ctx: RefinementCtx) => any; }; type PreprocessEffect = { type: "preprocess"; transform: (arg: T, ctx: RefinementCtx) => any; }; type Effect = RefinementEffect | TransformEffect | PreprocessEffect; interface ZodEffectsDef extends ZodTypeDef { schema: T; typeName: ZodFirstPartyTypeKind.ZodEffects; effect: Effect; } declare class ZodEffects, Input = input> extends ZodType, Input> { innerType(): T; sourceType(): T; _parse(input: ParseInput): ParseReturnType; static create: (schema: I, effect: Effect, params?: RawCreateParams) => ZodEffects; static createWithPreprocess: (preprocess: (arg: unknown, ctx: RefinementCtx) => unknown, schema: I, params?: RawCreateParams) => ZodEffects; } interface ZodOptionalDef extends ZodTypeDef { innerType: T; typeName: ZodFirstPartyTypeKind.ZodOptional; } declare class ZodOptional extends ZodType, T["_input"] | undefined> { _parse(input: ParseInput): ParseReturnType; unwrap(): T; static create: (type: T_1, params?: RawCreateParams) => ZodOptional; } interface ZodNullableDef extends ZodTypeDef { innerType: T; typeName: ZodFirstPartyTypeKind.ZodNullable; } declare class ZodNullable extends ZodType, T["_input"] | null> { _parse(input: ParseInput): ParseReturnType; unwrap(): T; static create: (type: T_1, params?: RawCreateParams) => ZodNullable; } interface ZodDefaultDef extends ZodTypeDef { innerType: T; defaultValue: () => util.noUndefined; typeName: ZodFirstPartyTypeKind.ZodDefault; } declare class ZodDefault extends ZodType, ZodDefaultDef, T["_input"] | undefined> { _parse(input: ParseInput): ParseReturnType; removeDefault(): T; static create: (type: T_1, params: { errorMap?: ZodErrorMap | undefined; invalid_type_error?: string | undefined; required_error?: string | undefined; message?: string | undefined; description?: string | undefined; } & { default: T_1["_input"] | (() => util.noUndefined); }) => ZodDefault; } interface ZodCatchDef extends ZodTypeDef { innerType: T; catchValue: (ctx: { error: ZodError; input: unknown; }) => T["_input"]; typeName: ZodFirstPartyTypeKind.ZodCatch; } declare class ZodCatch extends ZodType, unknown> { _parse(input: ParseInput): ParseReturnType; removeCatch(): T; static create: (type: T_1, params: { errorMap?: ZodErrorMap | undefined; invalid_type_error?: string | undefined; required_error?: string | undefined; message?: string | undefined; description?: string | undefined; } & { catch: T_1["_output"] | (() => T_1["_output"]); }) => ZodCatch; } interface ZodBrandedDef extends ZodTypeDef { type: T; typeName: ZodFirstPartyTypeKind.ZodBranded; } declare const BRAND: unique symbol; type BRAND = { [BRAND]: { [k in T]: true; }; }; declare class ZodBranded extends ZodType, ZodBrandedDef, T["_input"]> { _parse(input: ParseInput): ParseReturnType; unwrap(): T; } interface ZodPipelineDef extends ZodTypeDef { in: A; out: B; typeName: ZodFirstPartyTypeKind.ZodPipeline; } declare class ZodPipeline extends ZodType, A["_input"]> { _parse(input: ParseInput): ParseReturnType; static create(a: A, b: B): ZodPipeline; } type BuiltIn = (((...args: any[]) => any) | (new (...args: any[]) => any)) | { readonly [Symbol.toStringTag]: string; } | Date | Error | Generator | Promise | RegExp; type MakeReadonly = T extends Map ? ReadonlyMap : T extends Set ? ReadonlySet : T extends [infer Head, ...infer Tail] ? readonly [Head, ...Tail] : T extends Array ? ReadonlyArray : T extends BuiltIn ? T : Readonly; interface ZodReadonlyDef extends ZodTypeDef { innerType: T; typeName: ZodFirstPartyTypeKind.ZodReadonly; } declare class ZodReadonly extends ZodType, ZodReadonlyDef, MakeReadonly> { _parse(input: ParseInput): ParseReturnType; static create: (type: T_1, params?: RawCreateParams) => ZodReadonly; unwrap(): T; } declare enum ZodFirstPartyTypeKind { ZodString = "ZodString", ZodNumber = "ZodNumber", ZodNaN = "ZodNaN", ZodBigInt = "ZodBigInt", ZodBoolean = "ZodBoolean", ZodDate = "ZodDate", ZodSymbol = "ZodSymbol", ZodUndefined = "ZodUndefined", ZodNull = "ZodNull", ZodAny = "ZodAny", ZodUnknown = "ZodUnknown", ZodNever = "ZodNever", ZodVoid = "ZodVoid", ZodArray = "ZodArray", ZodObject = "ZodObject", ZodUnion = "ZodUnion", ZodDiscriminatedUnion = "ZodDiscriminatedUnion", ZodIntersection = "ZodIntersection", ZodTuple = "ZodTuple", ZodRecord = "ZodRecord", ZodMap = "ZodMap", ZodSet = "ZodSet", ZodFunction = "ZodFunction", ZodLazy = "ZodLazy", ZodLiteral = "ZodLiteral", ZodEnum = "ZodEnum", ZodEffects = "ZodEffects", ZodNativeEnum = "ZodNativeEnum", ZodOptional = "ZodOptional", ZodNullable = "ZodNullable", ZodDefault = "ZodDefault", ZodCatch = "ZodCatch", ZodPromise = "ZodPromise", ZodBranded = "ZodBranded", ZodPipeline = "ZodPipeline", ZodReadonly = "ZodReadonly" } declare const userSettingSchema: ZodObject<{ version: ZodNumber; userSince: ZodOptional; init: ZodOptional; }, "strip", ZodTypeAny, { skipOnboarding?: boolean | undefined; }, { skipOnboarding?: boolean | undefined; }>>; }, "strip", ZodTypeAny, { version: number; userSince?: number | undefined; init?: { skipOnboarding?: boolean | undefined; } | undefined; }, { version: number; userSince?: number | undefined; init?: { skipOnboarding?: boolean | undefined; } | undefined; }>; declare function globalSettings(filePath?: string): Promise; declare function _clearGlobalSettings(): void; /** * A class for reading and writing settings from a JSON file. Supports nested settings with dot * notation. */ declare class Settings { private filePath; value: TypeOf; /** * Create a new Settings instance * * @param filePath Path to the JSON settings file * @param value Loaded value of settings */ constructor(filePath: string, value: TypeOf); /** Save settings to the file */ save(): Promise; } export { ANGULAR_JSON_PATH, AngularJSON, type Builder, CommunityBuilder, CoreBuilder, CoreWebpackCompilers, type ExternalFramework, type NpmOptions, ProjectType, SUPPORTED_ESLINT_EXTENSIONS, SUPPORTED_RENDERERS, Settings, SupportedLanguage, type TemplateConfiguration, type TemplateMatcher, _clearGlobalSettings, addToDevDependenciesIfNotPresent, adjustTemplate, builderNameToCoreBuilder, cliStoriesTargetPath, coerceSemver, compilerNameToCoreCompiler, compoDocPreviewPrefix, configureEslintPlugin, configureFlatConfig, copyTemplate, copyTemplateFiles, detect, detectBuilder, detectFrameworkPreset, detectLanguage, detectPnp, externalFrameworks, extractEslintInfo, findEslintFile, frameworkToDefaultBuilder, getBabelDependencies, getRendererDir, getVersionSafe, globalSettings, hasStorybookDependencies, installableProjectTypes, isNxProject, isStorybookInstantiated, normalizeExtends, promptForCompoDocs, readFileAsJson, suggestESLintPlugin, supportedTemplates, unsupportedTemplate, writeFileAsJson };