@storybook/cli 0.0.0-pr-23609-sha-f47ef339

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/.eslintrc.js +36 -0
  2. package/README.md +70 -0
  3. package/__mocks__/@aw-web-design/x-default-browser.js +2 -0
  4. package/bin/index.js +9 -0
  5. package/dist/chunk-NECWGPZM.mjs +51 -0
  6. package/dist/generate.d.ts +2 -0
  7. package/dist/generate.js +462 -0
  8. package/dist/generate.mjs +467 -0
  9. package/dist/index.d.ts +308 -0
  10. package/dist/index.js +23 -0
  11. package/dist/index.mjs +1 -0
  12. package/jest.config.js +7 -0
  13. package/package.json +121 -0
  14. package/rendererAssets/.eslintrc.json +19 -0
  15. package/rendererAssets/common/Configure.mdx +364 -0
  16. package/rendererAssets/common/assets/accessibility.png +0 -0
  17. package/rendererAssets/common/assets/accessibility.svg +5 -0
  18. package/rendererAssets/common/assets/addon-library.png +0 -0
  19. package/rendererAssets/common/assets/assets.png +0 -0
  20. package/rendererAssets/common/assets/context.png +0 -0
  21. package/rendererAssets/common/assets/discord.svg +15 -0
  22. package/rendererAssets/common/assets/docs.png +0 -0
  23. package/rendererAssets/common/assets/figma-plugin.png +0 -0
  24. package/rendererAssets/common/assets/github.svg +3 -0
  25. package/rendererAssets/common/assets/share.png +0 -0
  26. package/rendererAssets/common/assets/styling.png +0 -0
  27. package/rendererAssets/common/assets/testing.png +0 -0
  28. package/rendererAssets/common/assets/theming.png +0 -0
  29. package/rendererAssets/common/assets/tutorials.svg +12 -0
  30. package/rendererAssets/common/assets/youtube.svg +4 -0
  31. package/rendererAssets/common/button.css +30 -0
  32. package/rendererAssets/common/header.css +32 -0
  33. package/rendererAssets/common/page.css +69 -0
  34. package/scripts/generate-sb-packages-versions.js +73 -0
  35. package/src/automigrate/fixes/__test__/main-config-with-wrappers.js +21 -0
  36. package/src/automigrate/fixes/__test__/main-config-without-wrappers.js +16 -0
  37. package/src/typings.d.ts +2 -0
  38. package/src/window.d.ts +8 -0
  39. package/templates/angular/application/template-csf/.storybook/tsconfig.json +11 -0
  40. package/templates/angular/application/template-csf/.storybook/typings.d.ts +4 -0
  41. package/templates/angular/library/template-csf/.storybook/tsconfig.json +11 -0
  42. package/templates/angular/library/template-csf/.storybook/typings.d.ts +4 -0
  43. package/templates/aurelia/template-csf/.storybook/tsconfig.json +9 -0
  44. package/templates/aurelia/template-csf/.storybook/typings.d.ts +4 -0
  45. package/test/default/cli.test.js +12 -0
  46. package/test/helpers.js +15 -0
@@ -0,0 +1,308 @@
1
+ import { CommonOptions } from 'execa';
2
+ import { PackageJson } from '@storybook/types';
3
+ export { PackageJson } from '@storybook/types';
4
+ import { WriteStream } from 'fs-extra';
5
+
6
+ declare const _default: {
7
+ '@storybook/addon-a11y': string;
8
+ '@storybook/addon-actions': string;
9
+ '@storybook/addon-backgrounds': string;
10
+ '@storybook/addon-controls': string;
11
+ '@storybook/addon-docs': string;
12
+ '@storybook/addon-essentials': string;
13
+ '@storybook/addon-highlight': string;
14
+ '@storybook/addon-interactions': string;
15
+ '@storybook/addon-jest': string;
16
+ '@storybook/addon-links': string;
17
+ '@storybook/addon-mdx-gfm': string;
18
+ '@storybook/addon-measure': string;
19
+ '@storybook/addon-outline': string;
20
+ '@storybook/addon-storyshots': string;
21
+ '@storybook/addon-storyshots-puppeteer': string;
22
+ '@storybook/addon-storysource': string;
23
+ '@storybook/addon-toolbars': string;
24
+ '@storybook/addon-viewport': string;
25
+ '@storybook/addons': string;
26
+ '@storybook/angular': string;
27
+ '@storybook/api': string;
28
+ '@storybook/blocks': string;
29
+ '@storybook/builder-manager': string;
30
+ '@storybook/builder-vite': string;
31
+ '@storybook/builder-webpack5': string;
32
+ '@storybook/channel-postmessage': string;
33
+ '@storybook/channel-websocket': string;
34
+ '@storybook/channels': string;
35
+ '@storybook/cli': string;
36
+ '@storybook/client-api': string;
37
+ '@storybook/client-logger': string;
38
+ '@storybook/codemod': string;
39
+ '@storybook/components': string;
40
+ '@storybook/core-client': string;
41
+ '@storybook/core-common': string;
42
+ '@storybook/core-events': string;
43
+ '@storybook/core-server': string;
44
+ '@storybook/core-webpack': string;
45
+ '@storybook/csf-plugin': string;
46
+ '@storybook/csf-tools': string;
47
+ '@storybook/docs-tools': string;
48
+ '@storybook/ember': string;
49
+ '@storybook/html': string;
50
+ '@storybook/html-vite': string;
51
+ '@storybook/html-webpack5': string;
52
+ '@storybook/instrumenter': string;
53
+ '@storybook/manager': string;
54
+ '@storybook/manager-api': string;
55
+ '@storybook/nextjs': string;
56
+ '@storybook/node-logger': string;
57
+ '@storybook/postinstall': string;
58
+ '@storybook/preact': string;
59
+ '@storybook/preact-vite': string;
60
+ '@storybook/preact-webpack5': string;
61
+ '@storybook/preset-create-react-app': string;
62
+ '@storybook/preset-html-webpack': string;
63
+ '@storybook/preset-preact-webpack': string;
64
+ '@storybook/preset-react-webpack': string;
65
+ '@storybook/preset-server-webpack': string;
66
+ '@storybook/preset-svelte-webpack': string;
67
+ '@storybook/preset-vue-webpack': string;
68
+ '@storybook/preset-vue3-webpack': string;
69
+ '@storybook/preset-web-components-webpack': string;
70
+ '@storybook/preview': string;
71
+ '@storybook/preview-api': string;
72
+ '@storybook/preview-web': string;
73
+ '@storybook/react': string;
74
+ '@storybook/react-dom-shim': string;
75
+ '@storybook/react-vite': string;
76
+ '@storybook/react-webpack5': string;
77
+ '@storybook/router': string;
78
+ '@storybook/server': string;
79
+ '@storybook/server-webpack5': string;
80
+ '@storybook/source-loader': string;
81
+ '@storybook/store': string;
82
+ '@storybook/svelte': string;
83
+ '@storybook/svelte-vite': string;
84
+ '@storybook/svelte-webpack5': string;
85
+ '@storybook/sveltekit': string;
86
+ '@storybook/telemetry': string;
87
+ '@storybook/theming': string;
88
+ '@storybook/types': string;
89
+ '@storybook/vue': string;
90
+ '@storybook/vue-vite': string;
91
+ '@storybook/vue-webpack5': string;
92
+ '@storybook/vue3': string;
93
+ '@storybook/vue3-vite': string;
94
+ '@storybook/vue3-webpack5': string;
95
+ '@storybook/web-components': string;
96
+ '@storybook/web-components-vite': string;
97
+ '@storybook/web-components-webpack5': string;
98
+ sb: string;
99
+ storybook: string;
100
+ };
101
+
102
+ declare const useNpmWarning: () => void;
103
+
104
+ type PackageJsonWithDepsAndDevDeps = PackageJson & Required<Pick<PackageJson, 'dependencies' | 'devDependencies'>>;
105
+ type PackageJsonWithMaybeDeps = Partial<Pick<PackageJson, 'dependencies' | 'devDependencies' | 'peerDependencies' | 'files'>>;
106
+
107
+ type PackageMetadata = {
108
+ version: string;
109
+ location?: string;
110
+ reasons?: string[];
111
+ };
112
+ type InstallationMetadata = {
113
+ dependencies: Record<string, PackageMetadata[]>;
114
+ duplicatedDependencies: Record<string, string[]>;
115
+ infoCommand: string;
116
+ };
117
+
118
+ type PackageManagerName = 'npm' | 'yarn1' | 'yarn2' | 'pnpm';
119
+ /**
120
+ * Extract package name and version from input
121
+ *
122
+ * @param pkg A string like `@storybook/cli`, `react` or `react@^16`
123
+ * @return A tuple of 2 elements: [packageName, packageVersion]
124
+ */
125
+ declare function getPackageDetails(pkg: string): [string, string?];
126
+ interface JsPackageManagerOptions {
127
+ cwd?: string;
128
+ }
129
+ declare abstract class JsPackageManager {
130
+ abstract readonly type: PackageManagerName;
131
+ abstract initPackageJson(): Promise<void>;
132
+ abstract getRunStorybookCommand(): string;
133
+ abstract getRunCommand(command: string): string;
134
+ readonly cwd?: string;
135
+ abstract getPackageJSON(packageName: string, basePath?: string): Promise<PackageJson | null>;
136
+ abstract getPackageVersion(packageName: string, basePath?: string): Promise<string | null>;
137
+ setRegistryURL(url: string): Promise<void>;
138
+ getRegistryURL(): Promise<string>;
139
+ constructor(options?: JsPackageManagerOptions);
140
+ /** Detect whether Storybook gets initialized in a monorepository/workspace environment
141
+ * The cwd doesn't have to be the root of the monorepo, it can be a subdirectory
142
+ * @returns true, if Storybook is initialized inside a monorepository/workspace
143
+ */
144
+ isStorybookInMonorepo(): boolean;
145
+ /**
146
+ * Install dependencies listed in `package.json`
147
+ */
148
+ installDependencies(): Promise<void>;
149
+ packageJsonPath(): string;
150
+ readPackageJson(): Promise<PackageJson>;
151
+ writePackageJson(packageJson: PackageJson): Promise<void>;
152
+ /**
153
+ * Read the `package.json` file available in the directory the command was call from
154
+ * If there is no `package.json` it will create one.
155
+ */
156
+ retrievePackageJson(): Promise<PackageJsonWithDepsAndDevDeps>;
157
+ getAllDependencies(): Promise<Record<string, string>>;
158
+ /**
159
+ * Add dependencies to a project using `yarn add` or `npm install`.
160
+ *
161
+ * @param {Object} options contains `skipInstall`, `packageJson` and `installAsDevDependencies` which we use to determine how we install packages.
162
+ * @param {Array} dependencies contains a list of packages to add.
163
+ * @example
164
+ * addDependencies(options, [
165
+ * `@storybook/react@${storybookVersion}`,
166
+ * `@storybook/addon-actions@${actionsVersion}`,
167
+ * `@storybook/addon-links@${linksVersion}`,
168
+ * `@storybook/preview-api@${addonsVersion}`,
169
+ * ]);
170
+ */
171
+ addDependencies(options: {
172
+ skipInstall?: boolean;
173
+ installAsDevDependencies?: boolean;
174
+ packageJson?: PackageJson;
175
+ }, dependencies: string[]): Promise<void>;
176
+ /**
177
+ * Remove dependencies from a project using `yarn remove` or `npm uninstall`.
178
+ *
179
+ * @param {Object} options contains `skipInstall`, `packageJson` and `installAsDevDependencies` which we use to determine how we install packages.
180
+ * @param {Array} dependencies contains a list of packages to remove.
181
+ * @example
182
+ * removeDependencies(options, [
183
+ * `@storybook/react`,
184
+ * `@storybook/addon-actions`,
185
+ * ]);
186
+ */
187
+ removeDependencies(options: {
188
+ skipInstall?: boolean;
189
+ packageJson?: PackageJson;
190
+ }, dependencies: string[]): Promise<void>;
191
+ /**
192
+ * Return an array of strings matching following format: `<package_name>@<package_latest_version>`
193
+ *
194
+ * @param packages
195
+ */
196
+ getVersionedPackages(packages: string[]): Promise<string[]>;
197
+ /**
198
+ * Return an array of string standing for the latest version of the input packages.
199
+ * To be able to identify which version goes with which package the order of the input array is keep.
200
+ *
201
+ * @param packageNames
202
+ */
203
+ getVersions(...packageNames: string[]): Promise<string[]>;
204
+ /**
205
+ * Return the latest version of the input package available on npmjs registry.
206
+ * If constraint are provided it return the latest version matching the constraints.
207
+ *
208
+ * For `@storybook/*` packages the latest version is retrieved from `cli/src/versions.json` file directly
209
+ *
210
+ * @param packageName The name of the package
211
+ * @param constraint A valid semver constraint, example: '1.x || >=2.5.0 || 5.0.0 - 7.2.3'
212
+ */
213
+ getVersion(packageName: string, constraint?: string): Promise<string>;
214
+ /**
215
+ * Get the latest version of the package available on npmjs.com.
216
+ * If constraint is set then it returns a version satisfying it, otherwise the latest version available is returned.
217
+ *
218
+ * @param packageName Name of the package
219
+ * @param constraint Version range to use to constraint the returned version
220
+ */
221
+ latestVersion(packageName: string, constraint?: string): Promise<string>;
222
+ addStorybookCommandInScripts(options?: {
223
+ port: number;
224
+ preCommand?: string;
225
+ }): Promise<void>;
226
+ addScripts(scripts: Record<string, string>): Promise<void>;
227
+ addPackageResolutions(versions: Record<string, string>): Promise<void>;
228
+ protected abstract runInstall(): Promise<void>;
229
+ protected abstract runAddDeps(dependencies: string[], installAsDevDependencies: boolean): Promise<void>;
230
+ protected abstract runRemoveDeps(dependencies: string[]): Promise<void>;
231
+ protected abstract getResolutions(packageJson: PackageJson, versions: Record<string, string>): Record<string, any>;
232
+ /**
233
+ * Get the latest or all versions of the input package available on npmjs.com
234
+ *
235
+ * @param packageName Name of the package
236
+ * @param fetchAllVersions Should return
237
+ */
238
+ protected abstract runGetVersions<T extends boolean>(packageName: string, fetchAllVersions: T): Promise<T extends true ? string[] : string>;
239
+ abstract runPackageCommand(command: string, args: string[], cwd?: string, stdio?: string): Promise<string>;
240
+ abstract runPackageCommandSync(command: string, args: string[], cwd?: string, stdio?: 'inherit' | 'pipe'): string;
241
+ abstract findInstallations(pattern?: string[]): Promise<InstallationMetadata | undefined>;
242
+ abstract parseErrorFromLogs(logs?: string): string;
243
+ executeCommandSync({ command, args, stdio, cwd, ignoreError, env, ...execaOptions }: CommonOptions<string> & {
244
+ command: string;
245
+ args: string[];
246
+ cwd?: string;
247
+ ignoreError?: boolean;
248
+ }): string;
249
+ executeCommand({ command, args, stdio, cwd, ignoreError, env, ...execaOptions }: CommonOptions<string> & {
250
+ command: string;
251
+ args: string[];
252
+ cwd?: string;
253
+ ignoreError?: boolean;
254
+ }): Promise<string>;
255
+ }
256
+
257
+ declare class JsPackageManagerFactory {
258
+ static getPackageManager({ force }?: {
259
+ force?: PackageManagerName;
260
+ }, cwd?: string): JsPackageManager;
261
+ }
262
+
263
+ declare function parseList(str: string): string[];
264
+ declare function getStorybookVersion(packageManager: JsPackageManager): Promise<string>;
265
+ declare function getEnvConfig(program: Record<string, any>, configEnv: Record<string, any>): void;
266
+ /**
267
+ * Given a file name, creates an object with utilities to manage a log file.
268
+ * It creates a temporary log file which you can manage with the returned functions.
269
+ * You can then decide whether to move the log file to the users project, or remove it.
270
+ *
271
+ * @example
272
+ * ```
273
+ * const { logStream, moveLogFile, removeLogFile, clearLogFile, readLogFile } = await createLogStream('my-log-file.log');
274
+ *
275
+ * // SCENARIO 1:
276
+ * // you can write custom messages to generate a log file
277
+ * logStream.write('my log message');
278
+ * await moveLogFile();
279
+ *
280
+ * // SCENARIO 2:
281
+ * // or you can pass it to stdio and capture the output of that command
282
+ * try {
283
+ * await this.executeCommand({
284
+ * command: 'pnpm',
285
+ * args: ['info', packageName, ...args],
286
+ * // do not output to the user, and send stdio and stderr to log file
287
+ * stdio: ['ignore', logStream, logStream]
288
+ * });
289
+ * } catch (err) {
290
+ * // do something with the log file content
291
+ * const output = await readLogFile();
292
+ * // move the log file to the users project
293
+ * await moveLogFile();
294
+ * }
295
+ * // success, no need to keep the log file
296
+ * await removeLogFile();
297
+ *
298
+ * ```
299
+ */
300
+ declare const createLogStream: (logFileName?: string) => Promise<{
301
+ moveLogFile: () => Promise<void>;
302
+ removeLogFile: () => Promise<void>;
303
+ clearLogFile: () => Promise<void>;
304
+ readLogFile: () => Promise<string>;
305
+ logStream: WriteStream;
306
+ }>;
307
+
308
+ export { JsPackageManager, JsPackageManagerFactory, PackageJsonWithDepsAndDevDeps, PackageJsonWithMaybeDeps, PackageManagerName, createLogStream, getEnvConfig, getPackageDetails, getStorybookVersion, parseList, useNpmWarning, _default as versions };
package/dist/index.js ADDED
@@ -0,0 +1,23 @@
1
+ var __create=Object.create;var __defProp=Object.defineProperty;var __getOwnPropDesc=Object.getOwnPropertyDescriptor;var __getOwnPropNames=Object.getOwnPropertyNames;var __getProtoOf=Object.getPrototypeOf,__hasOwnProp=Object.prototype.hasOwnProperty;var __export=(target,all)=>{for(var name in all)__defProp(target,name,{get:all[name],enumerable:!0})},__copyProps=(to,from,except,desc)=>{if(from&&typeof from=="object"||typeof from=="function")for(let key of __getOwnPropNames(from))!__hasOwnProp.call(to,key)&&key!==except&&__defProp(to,key,{get:()=>from[key],enumerable:!(desc=__getOwnPropDesc(from,key))||desc.enumerable});return to};var __toESM=(mod,isNodeMode,target)=>(target=mod!=null?__create(__getProtoOf(mod)):{},__copyProps(isNodeMode||!mod||!mod.__esModule?__defProp(target,"default",{value:mod,enumerable:!0}):target,mod)),__toCommonJS=mod=>__copyProps(__defProp({},"__esModule",{value:!0}),mod);var src_exports={};__export(src_exports,{JsPackageManager:()=>JsPackageManager,JsPackageManagerFactory:()=>JsPackageManagerFactory,createLogStream:()=>createLogStream,getEnvConfig:()=>getEnvConfig,getPackageDetails:()=>getPackageDetails,getStorybookVersion:()=>getStorybookVersion,parseList:()=>parseList,useNpmWarning:()=>useNpmWarning,versions:()=>versions_default});module.exports=__toCommonJS(src_exports);var versions_default={"@storybook/addon-a11y":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-actions":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-backgrounds":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-controls":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-docs":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-essentials":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-highlight":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-interactions":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-jest":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-links":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-mdx-gfm":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-measure":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-outline":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-storyshots":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-storyshots-puppeteer":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-storysource":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-toolbars":"0.0.0-pr-23609-sha-f47ef339","@storybook/addon-viewport":"0.0.0-pr-23609-sha-f47ef339","@storybook/addons":"0.0.0-pr-23609-sha-f47ef339","@storybook/angular":"0.0.0-pr-23609-sha-f47ef339","@storybook/api":"0.0.0-pr-23609-sha-f47ef339","@storybook/blocks":"0.0.0-pr-23609-sha-f47ef339","@storybook/builder-manager":"0.0.0-pr-23609-sha-f47ef339","@storybook/builder-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/builder-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/channel-postmessage":"0.0.0-pr-23609-sha-f47ef339","@storybook/channel-websocket":"0.0.0-pr-23609-sha-f47ef339","@storybook/channels":"0.0.0-pr-23609-sha-f47ef339","@storybook/cli":"0.0.0-pr-23609-sha-f47ef339","@storybook/client-api":"0.0.0-pr-23609-sha-f47ef339","@storybook/client-logger":"0.0.0-pr-23609-sha-f47ef339","@storybook/codemod":"0.0.0-pr-23609-sha-f47ef339","@storybook/components":"0.0.0-pr-23609-sha-f47ef339","@storybook/core-client":"0.0.0-pr-23609-sha-f47ef339","@storybook/core-common":"0.0.0-pr-23609-sha-f47ef339","@storybook/core-events":"0.0.0-pr-23609-sha-f47ef339","@storybook/core-server":"0.0.0-pr-23609-sha-f47ef339","@storybook/core-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/csf-plugin":"0.0.0-pr-23609-sha-f47ef339","@storybook/csf-tools":"0.0.0-pr-23609-sha-f47ef339","@storybook/docs-tools":"0.0.0-pr-23609-sha-f47ef339","@storybook/ember":"0.0.0-pr-23609-sha-f47ef339","@storybook/html":"0.0.0-pr-23609-sha-f47ef339","@storybook/html-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/html-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/instrumenter":"0.0.0-pr-23609-sha-f47ef339","@storybook/manager":"0.0.0-pr-23609-sha-f47ef339","@storybook/manager-api":"0.0.0-pr-23609-sha-f47ef339","@storybook/nextjs":"0.0.0-pr-23609-sha-f47ef339","@storybook/node-logger":"0.0.0-pr-23609-sha-f47ef339","@storybook/postinstall":"0.0.0-pr-23609-sha-f47ef339","@storybook/preact":"0.0.0-pr-23609-sha-f47ef339","@storybook/preact-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/preact-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-create-react-app":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-html-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-preact-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-react-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-server-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-svelte-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-vue-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-vue3-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preset-web-components-webpack":"0.0.0-pr-23609-sha-f47ef339","@storybook/preview":"0.0.0-pr-23609-sha-f47ef339","@storybook/preview-api":"0.0.0-pr-23609-sha-f47ef339","@storybook/preview-web":"0.0.0-pr-23609-sha-f47ef339","@storybook/react":"0.0.0-pr-23609-sha-f47ef339","@storybook/react-dom-shim":"0.0.0-pr-23609-sha-f47ef339","@storybook/react-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/react-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/router":"0.0.0-pr-23609-sha-f47ef339","@storybook/server":"0.0.0-pr-23609-sha-f47ef339","@storybook/server-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/source-loader":"0.0.0-pr-23609-sha-f47ef339","@storybook/store":"0.0.0-pr-23609-sha-f47ef339","@storybook/svelte":"0.0.0-pr-23609-sha-f47ef339","@storybook/svelte-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/svelte-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/sveltekit":"0.0.0-pr-23609-sha-f47ef339","@storybook/telemetry":"0.0.0-pr-23609-sha-f47ef339","@storybook/theming":"0.0.0-pr-23609-sha-f47ef339","@storybook/types":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue3":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue3-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/vue3-webpack5":"0.0.0-pr-23609-sha-f47ef339","@storybook/web-components":"0.0.0-pr-23609-sha-f47ef339","@storybook/web-components-vite":"0.0.0-pr-23609-sha-f47ef339","@storybook/web-components-webpack5":"0.0.0-pr-23609-sha-f47ef339",sb:"0.0.0-pr-23609-sha-f47ef339",storybook:"0.0.0-pr-23609-sha-f47ef339"};var import_util_deprecate=__toESM(require("util-deprecate")),useNpmWarning=(0,import_util_deprecate.default)(()=>{},"`--use-npm` is deprecated and will be removed in Storybook 8.0. \nPlease use the `--package-manager=npm` option instead.\nRead more at https://github.com/storybookjs/storybook/blob/next/MIGRATION.md#cli-option---use-npm-deprecated");var import_node_path=__toESM(require("path")),import_cross_spawn=require("cross-spawn"),import_find_up6=require("find-up");var import_sort=__toESM(require("semver/functions/sort")),import_os=require("os"),import_ts_dedent2=__toESM(require("ts-dedent")),import_find_up2=require("find-up"),import_fs2=require("fs"),import_path3=__toESM(require("path")),import_semver4=__toESM(require("semver"));var import_chalk2=__toESM(require("chalk")),import_semver3=require("semver"),import_execa=require("execa"),import_path=__toESM(require("path")),import_fs=__toESM(require("fs")),import_ts_dedent=__toESM(require("ts-dedent")),import_fs_extra2=require("fs-extra");var import_chalk=__toESM(require("chalk"));var import_fs_extra=__toESM(require("fs-extra"));var import_semver2=require("semver"),import_strip_json_comments=__toESM(require("strip-json-comments")),import_find_up=__toESM(require("find-up"));var import_get_tarball=__toESM(require("@ndelangen/get-tarball")),import_get_npm_tarball_url=__toESM(require("get-npm-tarball-url")),tempy=__toESM(require("tempy"));var import_semver=require("semver");var ProjectType=(ProjectType2=>(ProjectType2.UNDETECTED="UNDETECTED",ProjectType2.UNSUPPORTED="UNSUPPORTED",ProjectType2.REACT="REACT",ProjectType2.REACT_SCRIPTS="REACT_SCRIPTS",ProjectType2.REACT_NATIVE="REACT_NATIVE",ProjectType2.REACT_PROJECT="REACT_PROJECT",ProjectType2.WEBPACK_REACT="WEBPACK_REACT",ProjectType2.NEXTJS="NEXTJS",ProjectType2.VUE="VUE",ProjectType2.VUE3="VUE3",ProjectType2.SFC_VUE="SFC_VUE",ProjectType2.ANGULAR="ANGULAR",ProjectType2.EMBER="EMBER",ProjectType2.WEB_COMPONENTS="WEB_COMPONENTS",ProjectType2.HTML="HTML",ProjectType2.QWIK="QWIK",ProjectType2.PREACT="PREACT",ProjectType2.SVELTE="SVELTE",ProjectType2.SVELTEKIT="SVELTEKIT",ProjectType2.SERVER="SERVER",ProjectType2.NX="NX",ProjectType2.SOLID="SOLID",ProjectType2))(ProjectType||{});var notInstallableProjectTypes=["UNDETECTED","UNSUPPORTED"],installableProjectTypes=Object.values(ProjectType).filter(type=>!notInstallableProjectTypes.includes(type)).map(type=>type.toLowerCase());var logger=console;var commandLog=message=>(process.stdout.write(import_chalk.default.cyan(" \u2022 ")+message),(errorMessage,errorInfo)=>{if(errorMessage){if(process.stdout.write(`. ${import_chalk.default.red("\u2716")}
2
+ `),logger.error(`
3
+ ${import_chalk.default.red(errorMessage)}`),!errorInfo)return;let newErrorInfo=errorInfo.split(`
4
+ `).map(line=>` ${import_chalk.default.dim(line)}`).join(`
5
+ `);logger.error(`${newErrorInfo}
6
+ `);return}process.stdout.write(`. ${import_chalk.default.green("\u2713")}
7
+ `)});var HandledError=class extends Error{constructor(messageOrError){super(typeof messageOrError=="string"?messageOrError:messageOrError.message);this.handled=!0;typeof messageOrError!="string"&&(this.cause=messageOrError)}};var logger2=console;function getPackageDetails(pkg){let idx=pkg.lastIndexOf("@");if(idx<=0)return[pkg,void 0];let packageName=pkg.slice(0,idx),packageVersion=pkg.slice(idx+1);return[packageName,packageVersion]}var JsPackageManager=class{async setRegistryURL(url){url?await this.executeCommand({command:"npm",args:["config","set","registry",url]}):await this.executeCommand({command:"npm",args:["config","delete","registry"]})}async getRegistryURL(){let url=(await this.executeCommand({command:"npm",args:["config","get","registry"]})).trim();return url==="undefined"?void 0:url}constructor(options){this.cwd=(options==null?void 0:options.cwd)||process.cwd()}isStorybookInMonorepo(){let cwd=process.cwd();for(;;){try{let turboJsonPath=`${cwd}/turbo.json`,rushJsonPath=`${cwd}/rush.json`;if(import_fs.default.existsSync(turboJsonPath)||import_fs.default.existsSync(rushJsonPath))return!0;let packageJsonPath=require.resolve(`${cwd}/package.json`),packageJsonFile=(0,import_fs_extra2.readFileSync)(packageJsonPath,"utf8");if(JSON.parse(packageJsonFile).workspaces)return!0}catch{}let parentDir=import_path.default.dirname(cwd);if(parentDir===cwd)break;cwd=parentDir}return!1}async installDependencies(){let done=commandLog("Preparing to install dependencies");done(),logger2.log(),logger2.log(),done=commandLog("Installing dependencies");try{await this.runInstall(),done()}catch(e){throw done("An error occurred while installing dependencies."),new HandledError(e)}}packageJsonPath(){return import_path.default.resolve(this.cwd,"package.json")}async readPackageJson(){let packageJsonPath=this.packageJsonPath();if(!import_fs.default.existsSync(packageJsonPath))throw new Error(`Could not read package.json file at ${packageJsonPath}`);let jsonContent=await(0,import_fs_extra2.readFile)(packageJsonPath,"utf8");return JSON.parse(jsonContent)}async writePackageJson(packageJson){let packageJsonToWrite={...packageJson};packageJsonToWrite.dependencies&&Object.keys(packageJsonToWrite.dependencies).length===0&&delete packageJsonToWrite.dependencies,packageJsonToWrite.devDependencies&&Object.keys(packageJsonToWrite.devDependencies).length===0&&delete packageJsonToWrite.devDependencies,packageJsonToWrite.peerDependencies&&Object.keys(packageJsonToWrite.peerDependencies).length===0&&delete packageJsonToWrite.peerDependencies;let content=`${JSON.stringify(packageJsonToWrite,null,2)}
8
+ `;await(0,import_fs_extra2.writeFile)(this.packageJsonPath(),content,"utf8")}async retrievePackageJson(){let packageJson;try{packageJson=await this.readPackageJson()}catch(err){if(err.message.includes("Could not read package.json"))await this.initPackageJson(),packageJson=await this.readPackageJson();else throw new Error(import_ts_dedent.default`
9
+ There was an error while reading the package.json file at ${this.packageJsonPath()}: ${err.message}
10
+ Please fix the error and try again.
11
+ `)}return{...packageJson,dependencies:{...packageJson.dependencies},devDependencies:{...packageJson.devDependencies},peerDependencies:{...packageJson.peerDependencies}}}async getAllDependencies(){let{dependencies,devDependencies,peerDependencies}=await this.retrievePackageJson();return{...dependencies,...devDependencies,...peerDependencies}}async addDependencies(options,dependencies){let{skipInstall}=options;if(skipInstall){let{packageJson}=options,dependenciesMap=dependencies.reduce((acc,dep)=>{let[packageName,packageVersion]=getPackageDetails(dep);return{...acc,[packageName]:packageVersion}},{});options.installAsDevDependencies?packageJson.devDependencies={...packageJson.devDependencies,...dependenciesMap}:packageJson.dependencies={...packageJson.dependencies,...dependenciesMap},await this.writePackageJson(packageJson)}else try{await this.runAddDeps(dependencies,options.installAsDevDependencies)}catch(e){throw logger2.error(`
12
+ An error occurred while installing dependencies:`),logger2.log(e.message),new HandledError(e)}}async removeDependencies(options,dependencies){let{skipInstall}=options;if(skipInstall){let{packageJson}=options;dependencies.forEach(dep=>{packageJson.devDependencies&&delete packageJson.devDependencies[dep],packageJson.dependencies&&delete packageJson.dependencies[dep]}),await this.writePackageJson(packageJson)}else try{await this.runRemoveDeps(dependencies)}catch(e){throw logger2.error("An error occurred while removing dependencies."),logger2.log(e.message),new HandledError(e)}}getVersionedPackages(packages){return Promise.all(packages.map(async pkg=>{let[packageName,packageVersion]=getPackageDetails(pkg);return`${packageName}@${await this.getVersion(packageName,packageVersion)}`}))}getVersions(...packageNames){return Promise.all(packageNames.map(packageName=>this.getVersion(packageName)))}async getVersion(packageName,constraint){let current;/(@storybook|^sb$|^storybook$)/.test(packageName)&&(current=versions_default[packageName]);let latest;try{latest=await this.latestVersion(packageName,constraint)}catch(e){if(current)return logger2.warn(`
13
+ ${import_chalk2.default.yellow(e.message)}`),current;throw logger2.error(`
14
+ ${import_chalk2.default.red(e.message)}`),new HandledError(e)}return`^${current&&(!constraint||(0,import_semver3.satisfies)(current,constraint))&&(0,import_semver3.gt)(current,latest)?current:latest}`}async latestVersion(packageName,constraint){return constraint?(await this.runGetVersions(packageName,!0)).reverse().find(version=>(0,import_semver3.satisfies)(version,constraint)):this.runGetVersions(packageName,!1)}async addStorybookCommandInScripts(options){let storybookCmd=`storybook dev -p ${(options==null?void 0:options.port)??6006}`,buildStorybookCmd="storybook build",preCommand=options!=null&&options.preCommand?this.getRunCommand(options.preCommand):void 0;await this.addScripts({storybook:[preCommand,storybookCmd].filter(Boolean).join(" && "),"build-storybook":[preCommand,buildStorybookCmd].filter(Boolean).join(" && ")})}async addScripts(scripts){let packageJson=await this.retrievePackageJson();await this.writePackageJson({...packageJson,scripts:{...packageJson.scripts,...scripts}})}async addPackageResolutions(versions){let packageJson=await this.retrievePackageJson(),resolutions=this.getResolutions(packageJson,versions);this.writePackageJson({...packageJson,...resolutions})}executeCommandSync({command,args=[],stdio,cwd,ignoreError=!1,env,...execaOptions}){try{return(0,import_execa.sync)(command,args,{cwd:cwd??this.cwd,stdio:stdio??"pipe",encoding:"utf-8",shell:!0,cleanup:!0,env,...execaOptions}).stdout??""}catch(err){if(ignoreError!==!0)throw err;return""}}async executeCommand({command,args=[],stdio,cwd,ignoreError=!1,env,...execaOptions}){try{return(await(0,import_execa.command)([command,...args].join(" "),{cwd:cwd??this.cwd,stdio:stdio??"pipe",encoding:"utf-8",shell:!0,cleanup:!0,env,...execaOptions})).stdout??""}catch(err){if(ignoreError!==!0)throw err;return""}}};var import_fs_extra3=require("fs-extra"),import_path2=require("path"),import_tempy=__toESM(require("tempy")),import_core_common=require("@storybook/core-common");function parseList(str){return str.split(",").map(item=>item.trim()).filter(item=>item.length>0)}async function getStorybookVersion(packageManager){var _a;return(_a=(await Promise.all(Object.keys(import_core_common.rendererPackages).map(async pkg=>({name:pkg,version:await packageManager.getPackageVersion(pkg)})))).filter(({version})=>!!version)[0])==null?void 0:_a.version}function getEnvConfig(program,configEnv){Object.keys(configEnv).forEach(fieldName=>{let envVarName=configEnv[fieldName],envVarValue=process.env[envVarName];envVarValue&&(program[fieldName]=envVarValue)})}var createLogStream=async(logFileName="storybook.log")=>{let finalLogPath=(0,import_path2.join)(process.cwd(),logFileName),temporaryLogPath=import_tempy.default.file({name:logFileName}),logStream=(0,import_fs_extra3.createWriteStream)(temporaryLogPath,{encoding:"utf8"});return new Promise((resolve,reject)=>{logStream.once("open",()=>{resolve({logStream,moveLogFile:async()=>(0,import_fs_extra3.move)(temporaryLogPath,finalLogPath,{overwrite:!0}),clearLogFile:async()=>(0,import_fs_extra3.writeFile)(temporaryLogPath,""),removeLogFile:async()=>(0,import_fs_extra3.remove)(temporaryLogPath),readLogFile:async()=>(0,import_fs_extra3.readFile)(temporaryLogPath,"utf8")})}),logStream.once("error",reject)})};var NPM_ERROR_REGEX=/npm ERR! code (\w+)/,NPM_ERROR_CODES={E401:"Authentication failed or is required.",E403:"Access to the resource is forbidden.",E404:"Requested resource not found.",EACCES:"Permission issue.",EAI_FAIL:"DNS lookup failed.",EBADENGINE:"Engine compatibility check failed.",EBADPLATFORM:"Platform not supported.",ECONNREFUSED:"Connection refused.",ECONNRESET:"Connection reset.",EEXIST:"File or directory already exists.",EINVALIDTYPE:"Invalid type encountered.",EISGIT:"Git operation failed or conflicts with an existing file.",EJSONPARSE:"Error parsing JSON data.",EMISSINGARG:"Required argument missing.",ENEEDAUTH:"Authentication needed.",ENOAUDIT:"No audit available.",ENOENT:"File or directory does not exist.",ENOGIT:"Git not found or failed to run.",ENOLOCK:"Lockfile missing.",ENOSPC:"Insufficient disk space.",ENOTFOUND:"Resource not found.",EOTP:"One-time password required.",EPERM:"Permission error.",EPUBLISHCONFLICT:"Conflict during package publishing.",ERESOLVE:"Dependency resolution error.",EROFS:"File system is read-only.",ERR_SOCKET_TIMEOUT:"Socket timed out.",ETARGET:"Package target not found.",ETIMEDOUT:"Operation timed out.",ETOOMANYARGS:"Too many arguments provided.",EUNKNOWNTYPE:"Unknown type encountered."},NPMProxy=class extends JsPackageManager{constructor(){super(...arguments);this.type="npm"}async initPackageJson(){await this.executeCommand({command:"npm",args:["init","-y"]})}getRunStorybookCommand(){return"npm run storybook"}getRunCommand(command){return`npm run ${command}`}async getNpmVersion(){return this.executeCommand({command:"npm",args:["--version"]})}async getPackageJSON(packageName,basePath=this.cwd){let packageJsonPath=await(0,import_find_up2.sync)(dir=>{let possiblePath=import_path3.default.join(dir,"node_modules",packageName,"package.json");return(0,import_fs2.existsSync)(possiblePath)?possiblePath:void 0},{cwd:basePath});return packageJsonPath?JSON.parse((0,import_fs2.readFileSync)(packageJsonPath,"utf-8")):null}async getPackageVersion(packageName,basePath=this.cwd){var _a;let packageJson=await this.getPackageJSON(packageName,basePath);return packageJson?((_a=import_semver4.default.coerce(packageJson.version))==null?void 0:_a.version)??null:null}getInstallArgs(){return this.installArgs||(this.installArgs=[]),this.installArgs}runPackageCommandSync(command,args,cwd,stdio){return this.executeCommandSync({command:"npm",args:["exec","--",command,...args],cwd,stdio})}async runPackageCommand(command,args,cwd){return this.executeCommand({command:"npm",args:["exec","--",command,...args],cwd})}async findInstallations(){let pipeToNull=(0,import_os.platform)()==="win32"?"2>NUL":"2>/dev/null",commandResult=await this.executeCommand({command:"npm",args:["ls","--json","--depth=99",pipeToNull],ignoreError:!0});try{let parsedOutput=JSON.parse(commandResult);return this.mapDependencies(parsedOutput)}catch{return}}getResolutions(packageJson,versions){return{overrides:{...packageJson.overrides,...versions}}}async runInstall(){await this.executeCommand({command:"npm",args:["install",...this.getInstallArgs()],stdio:"inherit"})}async runAddDeps(dependencies,installAsDevDependencies){let{logStream,readLogFile,moveLogFile,removeLogFile}=await createLogStream(),args=[...dependencies];installAsDevDependencies&&(args=["-D",...args]);try{await this.executeCommand({command:"npm",args:["install",...args,...this.getInstallArgs()],stdio:["ignore",logStream,logStream]})}catch{let stdout=await readLogFile(),errorMessage=this.parseErrorFromLogs(stdout);throw await moveLogFile(),new Error(import_ts_dedent2.default`${errorMessage}
15
+
16
+ Please check the logfile generated at ./storybook.log for troubleshooting and try again.`)}await removeLogFile()}async runRemoveDeps(dependencies){let args=[...dependencies];await this.executeCommand({command:"npm",args:["uninstall",...this.getInstallArgs(),...args],stdio:"inherit"})}async runGetVersions(packageName,fetchAllVersions){let args=[fetchAllVersions?"versions":"version","--json"],commandResult=await this.executeCommand({command:"npm",args:["info",packageName,...args]});try{let parsedOutput=JSON.parse(commandResult);if(parsedOutput.error)throw new Error(parsedOutput.error.summary);return parsedOutput}catch{throw new Error(`Unable to find versions of ${packageName} using npm`)}}mapDependencies(input){let acc={},existingVersions={},duplicatedDependencies={},recurse=([name,packageInfo])=>{var _a;if(!name||!name.includes("storybook"))return;let value={version:packageInfo.version,location:""};(_a=existingVersions[name])!=null&&_a.includes(value.version)||(acc[name]?acc[name].push(value):acc[name]=[value],existingVersions[name]=(0,import_sort.default)([...existingVersions[name]||[],value.version]),existingVersions[name].length>1&&(duplicatedDependencies[name]=existingVersions[name])),packageInfo.dependencies&&Object.entries(packageInfo.dependencies).forEach(recurse)};return Object.entries(input.dependencies).forEach(recurse),{dependencies:acc,duplicatedDependencies,infoCommand:"npm ls --depth=1"}}parseErrorFromLogs(logs){let finalMessage="NPM error",match=logs.match(NPM_ERROR_REGEX);if(match){let errorCode=match[1];errorCode&&(finalMessage=`${finalMessage} ${errorCode}`);let errorMessage=NPM_ERROR_CODES[errorCode];errorMessage&&(finalMessage=`${finalMessage} - ${errorMessage}`)}return finalMessage.trim()}};var import_fs_extra4=require("fs-extra"),import_ts_dedent3=__toESM(require("ts-dedent")),import_find_up3=require("find-up"),import_path4=__toESM(require("path")),import_fs3=__toESM(require("fs")),import_semver5=__toESM(require("semver"));var PNPM_ERROR_REGEX=/(ELIFECYCLE|ERR_PNPM_[A-Z_]+)\s+(.*)/i,PNPMProxy=class extends JsPackageManager{constructor(){super(...arguments);this.type="pnpm"}detectWorkspaceRoot(){let pnpmWorkspaceYaml=`${process.cwd()}/pnpm-workspace.yaml`;return(0,import_fs_extra4.pathExistsSync)(pnpmWorkspaceYaml)}async initPackageJson(){await this.executeCommand({command:"pnpm",args:["init"]})}getRunStorybookCommand(){return"pnpm run storybook"}getRunCommand(command){return`pnpm run ${command}`}async getPnpmVersion(){return this.executeCommand({command:"pnpm",args:["--version"]})}getInstallArgs(){return this.installArgs||(this.installArgs=[],this.detectWorkspaceRoot()&&this.installArgs.push("-w")),this.installArgs}runPackageCommandSync(command,args,cwd,stdio){return this.executeCommandSync({command:"pnpm",args:["exec",command,...args],cwd,stdio})}async runPackageCommand(command,args,cwd){return this.executeCommand({command:"pnpm",args:["exec",command,...args],cwd})}async findInstallations(pattern){let commandResult=await this.executeCommand({command:"pnpm",args:["list",pattern.map(p=>`"${p}"`).join(" "),"--json","--depth=99"]});try{let parsedOutput=JSON.parse(commandResult);return this.mapDependencies(parsedOutput)}catch{return}}async getPackageJSON(packageName,basePath=this.cwd){let pnpapiPath=(0,import_find_up3.sync)([".pnp.js",".pnp.cjs"],{cwd:basePath});if(pnpapiPath)try{let pnpApi=require(pnpapiPath),resolvedPath=await pnpApi.resolveToUnqualified(packageName,basePath,{considerBuiltins:!1}),pkgLocator=pnpApi.findPackageLocator(resolvedPath),pkg=pnpApi.getPackageInformation(pkgLocator);return JSON.parse(import_fs3.default.readFileSync(import_path4.default.join(pkg.packageLocation,"package.json"),"utf-8"))}catch(error){return error.code!=="MODULE_NOT_FOUND"&&console.error("Error while fetching package version in PNPM PnP mode:",error),null}let packageJsonPath=await(0,import_find_up3.sync)(dir=>{let possiblePath=import_path4.default.join(dir,"node_modules",packageName,"package.json");return import_fs3.default.existsSync(possiblePath)?possiblePath:void 0},{cwd:basePath});return packageJsonPath?JSON.parse(import_fs3.default.readFileSync(packageJsonPath,"utf-8")):null}async getPackageVersion(packageName,basePath=this.cwd){var _a;let packageJSON=await this.getPackageJSON(packageName,basePath);return packageJSON?((_a=import_semver5.default.coerce(packageJSON.version))==null?void 0:_a.version)??null:null}getResolutions(packageJson,versions){return{overrides:{...packageJson.overrides,...versions}}}async runInstall(){await this.executeCommand({command:"pnpm",args:["install",...this.getInstallArgs()],stdio:"inherit"})}async runAddDeps(dependencies,installAsDevDependencies){let args=[...dependencies];installAsDevDependencies&&(args=["-D",...args]);let{logStream,readLogFile,moveLogFile,removeLogFile}=await createLogStream();try{await this.executeCommand({command:"pnpm",args:["add",...args,...this.getInstallArgs()],stdio:["ignore",logStream,logStream]})}catch{let stdout=await readLogFile(),errorMessage=this.parseErrorFromLogs(stdout);throw await moveLogFile(),new Error(import_ts_dedent3.default`${errorMessage}
17
+
18
+ Please check the logfile generated at ./storybook.log for troubleshooting and try again.`)}await removeLogFile()}async runRemoveDeps(dependencies){let args=[...dependencies];await this.executeCommand({command:"pnpm",args:["remove",...args,...this.getInstallArgs()],stdio:"inherit"})}async runGetVersions(packageName,fetchAllVersions){let args=[fetchAllVersions?"versions":"version","--json"],commandResult=await this.executeCommand({command:"pnpm",args:["info",packageName,...args]});try{let parsedOutput=JSON.parse(commandResult);if(parsedOutput.error)throw new Error(parsedOutput.error.summary);return parsedOutput}catch{throw new Error(`Unable to find versions of ${packageName} using pnpm`)}}mapDependencies(input){let acc={},existingVersions={},duplicatedDependencies={},items=input.reduce((curr,item)=>{let{devDependencies,dependencies,peerDependencies}=item,allDependencies={...devDependencies,...dependencies,...peerDependencies};return Object.assign(curr,allDependencies)},{}),recurse=([name,packageInfo])=>{var _a;if(!name||!name.includes("storybook"))return;let value={version:packageInfo.version,location:""};(_a=existingVersions[name])!=null&&_a.includes(value.version)||(acc[name]?acc[name].push(value):acc[name]=[value],existingVersions[name]=[...existingVersions[name]||[],value.version],existingVersions[name].length>1&&(duplicatedDependencies[name]=existingVersions[name])),packageInfo.dependencies&&Object.entries(packageInfo.dependencies).forEach(recurse)};return Object.entries(items).forEach(recurse),{dependencies:acc,duplicatedDependencies,infoCommand:"pnpm list --depth=1"}}parseErrorFromLogs(logs){let finalMessage="PNPM error",match=logs.match(PNPM_ERROR_REGEX);if(match){let[errorCode]=match;errorCode&&(finalMessage=`${finalMessage} ${errorCode}`)}return finalMessage.trim()}};var import_ts_dedent4=__toESM(require("ts-dedent")),import_find_up4=require("find-up"),import_fs4=require("fs"),import_path5=__toESM(require("path")),import_fslib=require("@yarnpkg/fslib"),import_libzip=require("@yarnpkg/libzip"),import_semver6=__toESM(require("semver"));var parsePackageData=(packageName="")=>{let[first,second,third]=packageName.trim().split("@"),version=(third||second).replace("npm:","");return{name:third?`@${second}`:first,value:{version,location:""}}};var YARN2_ERROR_REGEX=/(YN\d{4}):.*?Error:\s+(.*)/i,YARN2_ERROR_CODES={YN0000:"UNNAMED",YN0001:"EXCEPTION",YN0002:"MISSING_PEER_DEPENDENCY",YN0003:"CYCLIC_DEPENDENCIES",YN0004:"DISABLED_BUILD_SCRIPTS",YN0005:"BUILD_DISABLED",YN0006:"SOFT_LINK_BUILD",YN0007:"MUST_BUILD",YN0008:"MUST_REBUILD",YN0009:"BUILD_FAILED",YN0010:"RESOLVER_NOT_FOUND",YN0011:"FETCHER_NOT_FOUND",YN0012:"LINKER_NOT_FOUND",YN0013:"FETCH_NOT_CACHED",YN0014:"YARN_IMPORT_FAILED",YN0015:"REMOTE_INVALID",YN0016:"REMOTE_NOT_FOUND",YN0017:"RESOLUTION_PACK",YN0018:"CACHE_CHECKSUM_MISMATCH",YN0019:"UNUSED_CACHE_ENTRY",YN0020:"MISSING_LOCKFILE_ENTRY",YN0021:"WORKSPACE_NOT_FOUND",YN0022:"TOO_MANY_MATCHING_WORKSPACES",YN0023:"CONSTRAINTS_MISSING_DEPENDENCY",YN0024:"CONSTRAINTS_INCOMPATIBLE_DEPENDENCY",YN0025:"CONSTRAINTS_EXTRANEOUS_DEPENDENCY",YN0026:"CONSTRAINTS_INVALID_DEPENDENCY",YN0027:"CANT_SUGGEST_RESOLUTIONS",YN0028:"FROZEN_LOCKFILE_EXCEPTION",YN0029:"CROSS_DRIVE_VIRTUAL_LOCAL",YN0030:"FETCH_FAILED",YN0031:"DANGEROUS_NODE_MODULES",YN0032:"NODE_GYP_INJECTED",YN0046:"AUTOMERGE_FAILED_TO_PARSE",YN0047:"AUTOMERGE_IMMUTABLE",YN0048:"AUTOMERGE_SUCCESS",YN0049:"AUTOMERGE_REQUIRED",YN0050:"DEPRECATED_CLI_SETTINGS",YN0059:"INVALID_RANGE_PEER_DEPENDENCY",YN0060:"INCOMPATIBLE_PEER_DEPENDENCY",YN0061:"DEPRECATED_PACKAGE",YN0062:"INCOMPATIBLE_OS",YN0063:"INCOMPATIBLE_CPU",YN0068:"UNUSED_PACKAGE_EXTENSION",YN0069:"REDUNDANT_PACKAGE_EXTENSION",YN0071:"NM_CANT_INSTALL_EXTERNAL_SOFT_LINK",YN0072:"NM_PRESERVE_SYMLINKS_REQUIRED",YN0074:"NM_HARDLINKS_MODE_DOWNGRADED",YN0075:"PROLOG_INSTANTIATION_ERROR",YN0076:"INCOMPATIBLE_ARCHITECTURE",YN0077:"GHOST_ARCHITECTURE"},Yarn2Proxy=class extends JsPackageManager{constructor(){super(...arguments);this.type="yarn2"}getInstallArgs(){return this.installArgs||(this.installArgs=[]),this.installArgs}async initPackageJson(){await this.executeCommand({command:"yarn",args:["init"]})}getRunStorybookCommand(){return"yarn storybook"}getRunCommand(command){return`yarn ${command}`}runPackageCommandSync(command,args,cwd,stdio){return this.executeCommandSync({command:"yarn",args:[command,...args],cwd,stdio})}async runPackageCommand(command,args,cwd){return this.executeCommand({command:"yarn",args:[command,...args],cwd})}async findInstallations(pattern){let commandResult=await this.executeCommand({command:"yarn",args:["info","--name-only","--recursive",pattern.map(p=>`"${p}"`).join(" "),`"${pattern}"`]});try{return this.mapDependencies(commandResult)}catch{return}}async getPackageJSON(packageName,basePath=this.cwd){let pnpapiPath=(0,import_find_up4.sync)([".pnp.js",".pnp.cjs"],{cwd:basePath});if(pnpapiPath)try{let pnpApi=require(pnpapiPath),resolvedPath=await pnpApi.resolveToUnqualified(packageName,basePath,{considerBuiltins:!1}),pkgLocator=pnpApi.findPackageLocator(resolvedPath),pkg=pnpApi.getPackageInformation(pkgLocator),zipOpenFs=new import_fslib.ZipOpenFS({libzip:(0,import_libzip.getLibzipSync)()}),virtualFs=new import_fslib.VirtualFS({baseFs:zipOpenFs}),crossFs=new import_fslib.PosixFS(virtualFs),virtualPath=import_path5.default.join(pkg.packageLocation,"package.json");return crossFs.readJsonSync(virtualPath)}catch(error){return error.code!=="MODULE_NOT_FOUND"&&console.error("Error while fetching package version in Yarn PnP mode:",error),null}let packageJsonPath=await(0,import_find_up4.sync)(dir=>{let possiblePath=import_path5.default.join(dir,"node_modules",packageName,"package.json");return(0,import_fs4.existsSync)(possiblePath)?possiblePath:void 0},{cwd:basePath});return packageJsonPath?JSON.parse((0,import_fs4.readFileSync)(packageJsonPath,"utf-8")):null}async getPackageVersion(packageName,basePath=this.cwd){var _a;let packageJSON=await this.getPackageJSON(packageName,basePath);return packageJSON?((_a=import_semver6.default.coerce(packageJSON.version))==null?void 0:_a.version)??null:null}getResolutions(packageJson,versions){return{resolutions:{...packageJson.resolutions,...versions}}}async runInstall(){await this.executeCommand({command:"yarn",args:["install",...this.getInstallArgs()],stdio:"inherit"})}async runAddDeps(dependencies,installAsDevDependencies){let args=[...dependencies];installAsDevDependencies&&(args=["-D",...args]);let{logStream,readLogFile,moveLogFile,removeLogFile}=await createLogStream();try{await this.executeCommand({command:"yarn",args:["add",...this.getInstallArgs(),...args],stdio:["ignore",logStream,logStream]})}catch{let stdout=await readLogFile(),errorMessage=this.parseErrorFromLogs(stdout);throw await moveLogFile(),new Error(import_ts_dedent4.default`${errorMessage}
19
+
20
+ Please check the logfile generated at ./storybook.log for troubleshooting and try again.`)}await removeLogFile()}async runRemoveDeps(dependencies){let args=[...dependencies];await this.executeCommand({command:"yarn",args:["remove",...this.getInstallArgs(),...args],stdio:"inherit"})}async runGetVersions(packageName,fetchAllVersions){let field=fetchAllVersions?"versions":"version",args=["--fields",field,"--json"],commandResult=await this.executeCommand({command:"yarn",args:["npm","info",packageName,...args]});try{return JSON.parse(commandResult)[field]}catch{throw new Error(`Unable to find versions of ${packageName} using yarn 2`)}}mapDependencies(input){let lines=input.split(`
21
+ `),acc={},existingVersions={},duplicatedDependencies={};return lines.forEach(packageName=>{var _a;if(!packageName||!packageName.includes("storybook"))return;let{name,value}=parsePackageData(packageName.replaceAll('"',""));(_a=existingVersions[name])!=null&&_a.includes(value.version)||(acc[name]?acc[name].push(value):acc[name]=[value],existingVersions[name]=[...existingVersions[name]||[],value.version],existingVersions[name].length>1&&(duplicatedDependencies[name]=existingVersions[name]))}),{dependencies:acc,duplicatedDependencies,infoCommand:"yarn why"}}parseErrorFromLogs(logs){let finalMessage="YARN2 error",match=logs.match(YARN2_ERROR_REGEX);if(match){let errorCode=match[1];errorCode&&(finalMessage=`${finalMessage} ${errorCode}`);let errorType=YARN2_ERROR_CODES[errorCode];errorType&&(finalMessage=`${finalMessage} - ${errorType}`);let errorMessage=match[2];errorMessage&&(finalMessage=`${finalMessage}: ${errorMessage}`)}return finalMessage.trim()}};var import_ts_dedent5=__toESM(require("ts-dedent")),import_find_up5=require("find-up"),import_fs5=require("fs"),import_path6=__toESM(require("path")),import_semver7=__toESM(require("semver"));var YARN1_ERROR_REGEX=/^error\s(.*)$/gm,Yarn1Proxy=class extends JsPackageManager{constructor(){super(...arguments);this.type="yarn1"}getInstallArgs(){return this.installArgs||(this.installArgs=["--ignore-workspace-root-check"]),this.installArgs}async initPackageJson(){await this.executeCommand({command:"yarn",args:["init","-y"]})}getRunStorybookCommand(){return"yarn storybook"}getRunCommand(command){return`yarn ${command}`}runPackageCommandSync(command,args,cwd,stdio){return this.executeCommandSync({command:"yarn",args:[command,...args],cwd,stdio})}async runPackageCommand(command,args,cwd){return this.executeCommand({command:"yarn",args:[command,...args],cwd})}async getPackageJSON(packageName,basePath=this.cwd){let packageJsonPath=await(0,import_find_up5.sync)(dir=>{let possiblePath=import_path6.default.join(dir,"node_modules",packageName,"package.json");return(0,import_fs5.existsSync)(possiblePath)?possiblePath:void 0},{cwd:basePath});return packageJsonPath?JSON.parse((0,import_fs5.readFileSync)(packageJsonPath,"utf-8")):null}async getPackageVersion(packageName,basePath=this.cwd){var _a;let packageJson=await this.getPackageJSON(packageName,basePath);return packageJson?((_a=import_semver7.default.coerce(packageJson.version))==null?void 0:_a.version)??null:null}async findInstallations(pattern){let commandResult=await this.executeCommand({command:"yarn",args:["list","--pattern",pattern.map(p=>`"${p}"`).join(" "),"--recursive","--json"]});try{let parsedOutput=JSON.parse(commandResult);return this.mapDependencies(parsedOutput)}catch{return}}getResolutions(packageJson,versions){return{resolutions:{...packageJson.resolutions,...versions}}}async runInstall(){await this.executeCommand({command:"yarn",args:["install",...this.getInstallArgs()],stdio:"inherit"})}async runAddDeps(dependencies,installAsDevDependencies){let args=[...dependencies];installAsDevDependencies&&(args=["-D",...args]);let{logStream,readLogFile,moveLogFile,removeLogFile}=await createLogStream();try{await this.executeCommand({command:"yarn",args:["add",...this.getInstallArgs(),...args],stdio:["ignore",logStream,logStream]})}catch{let stdout=await readLogFile(),errorMessage=this.parseErrorFromLogs(stdout);throw await moveLogFile(),new Error(import_ts_dedent5.default`${errorMessage}
22
+
23
+ Please check the logfile generated at ./storybook.log for troubleshooting and try again.`)}await removeLogFile()}async runRemoveDeps(dependencies){let args=[...dependencies];await this.executeCommand({command:"yarn",args:["remove",...this.getInstallArgs(),...args],stdio:"inherit"})}async runGetVersions(packageName,fetchAllVersions){let args=[fetchAllVersions?"versions":"version","--json"],commandResult=await this.executeCommand({command:"yarn",args:["info",packageName,...args]});try{let parsedOutput=JSON.parse(commandResult);if(parsedOutput.type==="inspect")return parsedOutput.data;throw new Error(`Unable to find versions of ${packageName} using yarn`)}catch{throw new Error(`Unable to find versions of ${packageName} using yarn`)}}mapDependencies(input){if(input.type==="tree"){let{trees}=input.data,acc={},existingVersions={},duplicatedDependencies={},recurse=tree=>{var _a;let{children}=tree,{name,value}=parsePackageData(tree.name);!name||!name.includes("storybook")||((_a=existingVersions[name])!=null&&_a.includes(value.version)||(acc[name]?acc[name].push(value):acc[name]=[value],existingVersions[name]=[...existingVersions[name]||[],value.version],existingVersions[name].length>1&&(duplicatedDependencies[name]=existingVersions[name])),children.forEach(recurse))};return trees.forEach(recurse),{dependencies:acc,duplicatedDependencies,infoCommand:"yarn why"}}throw new Error("Something went wrong while parsing yarn output")}parseErrorFromLogs(logs){var _a;let finalMessage="YARN1 error",match=logs.match(YARN1_ERROR_REGEX);if(match){let errorMessage=(_a=match[0])==null?void 0:_a.replace(/^error\s(.*)$/,"$1");errorMessage&&(finalMessage=`${finalMessage}: ${errorMessage}`)}return finalMessage.trim()}};var NPM_LOCKFILE="package-lock.json",PNPM_LOCKFILE="pnpm-lock.yaml",YARN_LOCKFILE="yarn.lock",JsPackageManagerFactory=class{static getPackageManager({force}={},cwd){if(force==="npm")return new NPMProxy({cwd});if(force==="pnpm")return new PNPMProxy({cwd});if(force==="yarn1")return new Yarn1Proxy({cwd});if(force==="yarn2")return new Yarn2Proxy({cwd});let yarnVersion=getYarnVersion(cwd),closestLockfilePath=(0,import_find_up6.sync)([YARN_LOCKFILE,PNPM_LOCKFILE,NPM_LOCKFILE],{cwd}),closestLockfile=closestLockfilePath&&import_node_path.default.basename(closestLockfilePath),hasNPMCommand=hasNPM(cwd),hasPNPMCommand=hasPNPM(cwd);if(yarnVersion&&(closestLockfile===YARN_LOCKFILE||!hasNPMCommand&&!hasPNPMCommand))return yarnVersion===1?new Yarn1Proxy({cwd}):new Yarn2Proxy({cwd});if(hasPNPMCommand&&closestLockfile===PNPM_LOCKFILE)return new PNPMProxy({cwd});if(hasNPMCommand)return new NPMProxy({cwd});throw new Error("Unable to find a usable package manager within NPM, PNPM, Yarn and Yarn 2")}};function hasNPM(cwd){return(0,import_cross_spawn.sync)("npm",["--version"],{cwd,shell:!0}).status===0}function hasPNPM(cwd){return(0,import_cross_spawn.sync)("pnpm",["--version"],{cwd,shell:!0}).status===0}function getYarnVersion(cwd){let yarnVersionCommand=(0,import_cross_spawn.sync)("yarn",["--version"],{cwd,shell:!0});if(yarnVersionCommand.status!==0)return;let yarnVersion=yarnVersionCommand.output.toString().replace(/,/g,"").replace(/"/g,"");return/^1\.+/.test(yarnVersion)?1:2}0&&(module.exports={JsPackageManager,JsPackageManagerFactory,createLogStream,getEnvConfig,getPackageDetails,getStorybookVersion,parseList,useNpmWarning,versions});
package/dist/index.mjs ADDED
@@ -0,0 +1 @@
1
+ export { JsPackageManager, JsPackageManagerFactory, createLogStream, getEnvConfig, getPackageDetails, getStorybookVersion, parseList, useNpmWarning, versions_default as versions } from './chunk-NECWGPZM.mjs';
package/jest.config.js ADDED
@@ -0,0 +1,7 @@
1
+ const path = require('path');
2
+ const baseConfig = require('../../jest.config.node');
3
+
4
+ module.exports = {
5
+ ...baseConfig,
6
+ displayName: __dirname.split(path.sep).slice(-2).join(path.posix.sep),
7
+ };
package/package.json ADDED
@@ -0,0 +1,121 @@
1
+ {
2
+ "name": "@storybook/cli",
3
+ "version": "0.0.0-pr-23609-sha-f47ef339",
4
+ "description": "Storybook's CLI - easiest method of adding storybook to your projects",
5
+ "keywords": [
6
+ "cli",
7
+ "generator",
8
+ "storybook"
9
+ ],
10
+ "homepage": "https://github.com/storybookjs/storybook/tree/next/code/lib/cli",
11
+ "bugs": {
12
+ "url": "https://github.com/storybookjs/storybook/issues"
13
+ },
14
+ "repository": {
15
+ "type": "git",
16
+ "url": "https://github.com/storybookjs/storybook.git",
17
+ "directory": "code/lib/cli"
18
+ },
19
+ "funding": {
20
+ "type": "opencollective",
21
+ "url": "https://opencollective.com/storybook"
22
+ },
23
+ "license": "MIT",
24
+ "author": "Storybook Team",
25
+ "exports": {
26
+ ".": {
27
+ "types": "./dist/index.d.ts",
28
+ "node": "./dist/index.js",
29
+ "require": "./dist/index.js",
30
+ "import": "./dist/index.mjs"
31
+ },
32
+ "./package.json": "./package.json",
33
+ "./bin/index": "./bin/index.js"
34
+ },
35
+ "main": "dist/index.js",
36
+ "module": "dist/index.mjs",
37
+ "types": "dist/index.d.ts",
38
+ "bin": {
39
+ "getstorybook": "./bin/index.js",
40
+ "sb": "./bin/index.js"
41
+ },
42
+ "files": [
43
+ "bin/**/*",
44
+ "dist/**/*",
45
+ "rendererAssets/**/*",
46
+ "templates/**/*",
47
+ "README.md",
48
+ "*.js",
49
+ "*.d.ts"
50
+ ],
51
+ "scripts": {
52
+ "check": "../../../scripts/prepare/check.ts",
53
+ "prep": "../../../scripts/prepare/bundle.ts",
54
+ "test": "jest test/**/*.test.js"
55
+ },
56
+ "dependencies": {
57
+ "@babel/core": "^7.22.9",
58
+ "@babel/preset-env": "^7.22.9",
59
+ "@babel/types": "^7.22.5",
60
+ "@ndelangen/get-tarball": "^3.0.7",
61
+ "@storybook/codemod": "0.0.0-pr-23609-sha-f47ef339",
62
+ "@storybook/core-common": "0.0.0-pr-23609-sha-f47ef339",
63
+ "@storybook/core-server": "0.0.0-pr-23609-sha-f47ef339",
64
+ "@storybook/csf-tools": "0.0.0-pr-23609-sha-f47ef339",
65
+ "@storybook/node-logger": "0.0.0-pr-23609-sha-f47ef339",
66
+ "@storybook/telemetry": "0.0.0-pr-23609-sha-f47ef339",
67
+ "@storybook/types": "0.0.0-pr-23609-sha-f47ef339",
68
+ "@types/semver": "^7.3.4",
69
+ "@yarnpkg/fslib": "2.10.3",
70
+ "@yarnpkg/libzip": "2.3.0",
71
+ "chalk": "^4.1.0",
72
+ "commander": "^6.2.1",
73
+ "cross-spawn": "^7.0.3",
74
+ "detect-indent": "^6.1.0",
75
+ "envinfo": "^7.7.3",
76
+ "execa": "^5.0.0",
77
+ "express": "^4.17.3",
78
+ "find-up": "^5.0.0",
79
+ "fs-extra": "^11.1.0",
80
+ "get-npm-tarball-url": "^2.0.3",
81
+ "get-port": "^5.1.1",
82
+ "giget": "^1.0.0",
83
+ "globby": "^11.0.2",
84
+ "jscodeshift": "^0.14.0",
85
+ "leven": "^3.1.0",
86
+ "ora": "^5.4.1",
87
+ "prettier": "^2.8.0",
88
+ "prompts": "^2.4.0",
89
+ "puppeteer-core": "^2.1.1",
90
+ "read-pkg-up": "^7.0.1",
91
+ "semver": "^7.3.7",
92
+ "simple-update-notifier": "^2.0.0",
93
+ "strip-json-comments": "^3.0.1",
94
+ "tempy": "^1.0.1",
95
+ "ts-dedent": "^2.0.0",
96
+ "util-deprecate": "^1.0.2"
97
+ },
98
+ "devDependencies": {
99
+ "@storybook/client-api": "0.0.0-pr-23609-sha-f47ef339",
100
+ "@types/cross-spawn": "^6.0.2",
101
+ "@types/prompts": "^2.0.9",
102
+ "@types/puppeteer-core": "^2.1.0",
103
+ "@types/semver": "^7.3.4",
104
+ "@types/util-deprecate": "^1.0.0",
105
+ "boxen": "^5.1.2",
106
+ "slash": "^5.0.0",
107
+ "strip-json-comments": "^3.1.1",
108
+ "typescript": "~4.9.3"
109
+ },
110
+ "publishConfig": {
111
+ "access": "public"
112
+ },
113
+ "bundler": {
114
+ "entries": [
115
+ "./src/generate.ts",
116
+ "./src/index.ts"
117
+ ],
118
+ "platform": "node"
119
+ },
120
+ "gitHead": "e6a7fd8a655c69780bc20b9749c2699e44beae17"
121
+ }
@@ -0,0 +1,19 @@
1
+ {
2
+ "rules": {
3
+ "no-undef": "off",
4
+ "@typescript-eslint/ban-types": "off",
5
+ "react/prop-types": "off",
6
+ "react/react-in-jsx-scope": "off",
7
+ "import/extensions": "off",
8
+ "import/no-unresolved": "off",
9
+ "import/no-extraneous-dependencies": "off"
10
+ },
11
+ "overrides": [
12
+ {
13
+ "files": ["nextjs/**/*.@(jsx|tsx)"],
14
+ "rules": {
15
+ "react/no-unknown-property": "off"
16
+ }
17
+ }
18
+ ]
19
+ }