@storybook/core-server 7.0.0-alpha.50 → 7.0.0-alpha.51

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 (59) hide show
  1. package/dist/cjs/__for-testing__/main.js +1 -0
  2. package/dist/cjs/build-dev.js +33 -71
  3. package/dist/cjs/build-static.js +14 -68
  4. package/dist/cjs/core-presets.disabled-test.js +23 -59
  5. package/dist/cjs/dev-server.js +20 -58
  6. package/dist/cjs/index.js +0 -7
  7. package/dist/cjs/presets/babel-cache-preset.js +0 -6
  8. package/dist/cjs/presets/common-preset.js +1 -48
  9. package/dist/cjs/standalone.js +4 -17
  10. package/dist/cjs/utils/StoryIndexGenerator.js +45 -114
  11. package/dist/cjs/utils/__mockdata__/errors/NoMeta.stories.js +0 -1
  12. package/dist/cjs/utils/__mockdata__/errors/NoStories.stories.js +0 -1
  13. package/dist/cjs/utils/copy-all-static-files.js +11 -28
  14. package/dist/cjs/utils/get-builders.js +0 -8
  15. package/dist/cjs/utils/get-server-channel.js +0 -10
  16. package/dist/cjs/utils/metadata.js +0 -4
  17. package/dist/cjs/utils/middleware.js +2 -11
  18. package/dist/cjs/utils/open-in-browser.js +1 -7
  19. package/dist/cjs/utils/output-startup-information.js +8 -16
  20. package/dist/cjs/utils/output-stats.js +2 -20
  21. package/dist/cjs/utils/release-notes.js +5 -22
  22. package/dist/cjs/utils/server-address.js +0 -10
  23. package/dist/cjs/utils/server-init.js +0 -11
  24. package/dist/cjs/utils/server-statics.js +3 -32
  25. package/dist/cjs/utils/stories-json.js +1 -22
  26. package/dist/cjs/utils/summarizeIndex.js +0 -1
  27. package/dist/cjs/utils/update-check.js +7 -23
  28. package/dist/cjs/utils/watch-story-specifiers.js +14 -26
  29. package/dist/cjs/withTelemetry.js +17 -27
  30. package/dist/esm/__for-testing__/main.js +1 -0
  31. package/dist/esm/build-dev.js +33 -56
  32. package/dist/esm/build-static.js +14 -49
  33. package/dist/esm/core-presets.disabled-test.js +25 -47
  34. package/dist/esm/dev-server.js +22 -40
  35. package/dist/esm/index.js +1 -0
  36. package/dist/esm/presets/babel-cache-preset.js +2 -5
  37. package/dist/esm/presets/common-preset.js +1 -16
  38. package/dist/esm/standalone.js +4 -14
  39. package/dist/esm/utils/StoryIndexGenerator.js +46 -97
  40. package/dist/esm/utils/copy-all-static-files.js +11 -13
  41. package/dist/esm/utils/get-builders.js +0 -5
  42. package/dist/esm/utils/get-server-channel.js +0 -3
  43. package/dist/esm/utils/middleware.js +2 -8
  44. package/dist/esm/utils/open-in-browser.js +0 -1
  45. package/dist/esm/utils/output-startup-information.js +8 -7
  46. package/dist/esm/utils/output-stats.js +2 -10
  47. package/dist/esm/utils/release-notes.js +5 -14
  48. package/dist/esm/utils/server-init.js +0 -3
  49. package/dist/esm/utils/server-statics.js +3 -16
  50. package/dist/esm/utils/stories-json.js +1 -12
  51. package/dist/esm/utils/update-check.js +7 -12
  52. package/dist/esm/utils/watch-story-specifiers.js +14 -18
  53. package/dist/esm/withTelemetry.js +17 -23
  54. package/dist/types/presets/common-preset.d.ts +5 -2
  55. package/dist/types/utils/StoryIndexGenerator.d.ts +3 -3
  56. package/dist/types/utils/get-server-channel.d.ts +1 -1
  57. package/dist/types/utils/server-init.d.ts +1 -0
  58. package/dist/types/withTelemetry.d.ts +1 -1
  59. package/package.json +15 -15
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  /// <reference types="node" />
7
7
  // eslint-disable-next-line @typescript-eslint/ban-ts-comment
8
8
  // @ts-ignore
9
+
9
10
  var config = {
10
11
  stories: ['../../ui/manager/src/**/*.stories.@(ts|tsx|js|jsx|mdx)', '../../ui/components/src/**/*.stories.@(ts|tsx|js|jsx|mdx)', './../../addons/docs/**/*.stories.@(ts|tsx|js|jsx|mdx)', './../../addons/interactions/**/*.stories.@(ts|tsx|js|jsx|mdx)'],
11
12
  addons: [{
@@ -4,82 +4,57 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.buildDevStandalone = buildDevStandalone;
7
-
8
7
  var _coreCommon = require("@storybook/core-common");
9
-
10
8
  var _prompts = _interopRequireDefault(require("prompts"));
11
-
12
9
  var _global = _interopRequireDefault(require("global"));
13
-
14
10
  var _path = require("path");
15
-
16
11
  var _nodeLogger = require("@storybook/node-logger");
17
-
18
12
  var _devServer = require("./dev-server");
19
-
20
13
  var _releaseNotes = require("./utils/release-notes");
21
-
22
14
  var _outputStats = require("./utils/output-stats");
23
-
24
15
  var _outputStartupInformation = require("./utils/output-startup-information");
25
-
26
16
  var _updateCheck = require("./utils/update-check");
27
-
28
17
  var _serverAddress = require("./utils/server-address");
29
-
30
18
  var _getBuilders = require("./utils/get-builders");
31
-
32
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
33
-
34
20
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
35
-
36
21
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
37
-
38
22
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
39
-
40
23
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
41
-
42
24
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
43
-
44
25
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
45
-
46
26
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
47
-
48
27
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
49
-
50
28
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
51
-
52
29
  async function buildDevStandalone(options) {
53
30
  var packageJson = options.packageJson,
54
- versionUpdates = options.versionUpdates,
55
- releaseNotes = options.releaseNotes;
56
- var version = packageJson.version; // updateInfo and releaseNotesData are cached, so this is typically pretty fast
31
+ versionUpdates = options.versionUpdates,
32
+ releaseNotes = options.releaseNotes;
33
+ var version = packageJson.version;
57
34
 
35
+ // updateInfo and releaseNotesData are cached, so this is typically pretty fast
58
36
  var _await$Promise$all = await Promise.all([(0, _serverAddress.getServerPort)(options.port), versionUpdates ? (0, _updateCheck.updateCheck)(version) : Promise.resolve({
59
- success: false,
60
- cached: false,
61
- data: {},
62
- time: Date.now()
63
- }), releaseNotes ? (0, _releaseNotes.getReleaseNotesData)(version, _coreCommon.cache) : Promise.resolve((0, _releaseNotes.getReleaseNotesFailedState)(version))]),
64
- _await$Promise$all2 = _slicedToArray(_await$Promise$all, 3),
65
- port = _await$Promise$all2[0],
66
- versionCheck = _await$Promise$all2[1],
67
- releaseNotesData = _await$Promise$all2[2];
68
-
37
+ success: false,
38
+ cached: false,
39
+ data: {},
40
+ time: Date.now()
41
+ }), releaseNotes ? (0, _releaseNotes.getReleaseNotesData)(version, _coreCommon.cache) : Promise.resolve((0, _releaseNotes.getReleaseNotesFailedState)(version))]),
42
+ _await$Promise$all2 = _slicedToArray(_await$Promise$all, 3),
43
+ port = _await$Promise$all2[0],
44
+ versionCheck = _await$Promise$all2[1],
45
+ releaseNotesData = _await$Promise$all2[2];
69
46
  if (!options.ci && !options.smokeTest && options.port != null && port !== options.port) {
70
47
  var _await$prompts = await (0, _prompts.default)({
71
- type: 'confirm',
72
- initial: true,
73
- name: 'shouldChangePort',
74
- message: `Port ${options.port} is not available. Would you like to run Storybook on port ${port} instead?`
75
- }),
76
- shouldChangePort = _await$prompts.shouldChangePort;
77
-
48
+ type: 'confirm',
49
+ initial: true,
50
+ name: 'shouldChangePort',
51
+ message: `Port ${options.port} is not available. Would you like to run Storybook on port ${port} instead?`
52
+ }),
53
+ shouldChangePort = _await$prompts.shouldChangePort;
78
54
  if (!shouldChangePort) process.exit(1);
79
55
  }
80
- /* eslint-disable no-param-reassign */
81
-
82
56
 
57
+ /* eslint-disable no-param-reassign */
83
58
  options.port = port;
84
59
  options.versionCheck = versionCheck;
85
60
  options.releaseNotesData = releaseNotesData;
@@ -90,66 +65,53 @@ async function buildDevStandalone(options) {
90
65
  /* eslint-enable no-param-reassign */
91
66
 
92
67
  var _loadMainConfig = (0, _coreCommon.loadMainConfig)(options),
93
- framework = _loadMainConfig.framework;
94
-
68
+ framework = _loadMainConfig.framework;
95
69
  var corePresets = [];
96
70
  var frameworkName = typeof framework === 'string' ? framework : framework === null || framework === void 0 ? void 0 : framework.name;
97
71
  (0, _coreCommon.validateFrameworkName)(frameworkName);
98
-
99
72
  if (frameworkName) {
100
73
  corePresets.push((0, _path.join)(frameworkName, 'preset'));
101
74
  } else {
102
75
  _nodeLogger.logger.warn(`you have not specified a framework in your ${options.configDir}/main.js`);
103
76
  }
104
-
105
77
  _nodeLogger.logger.info('=> Loading presets');
106
-
107
78
  var presets = await (0, _coreCommon.loadAllPresets)(_objectSpread({
108
79
  corePresets: corePresets,
109
80
  overridePresets: []
110
81
  }, options));
111
-
112
82
  var _await$getBuilders = await (0, _getBuilders.getBuilders)(_objectSpread(_objectSpread({}, options), {}, {
113
- presets: presets
114
- })),
115
- _await$getBuilders2 = _slicedToArray(_await$getBuilders, 2),
116
- previewBuilder = _await$getBuilders2[0],
117
- managerBuilder = _await$getBuilders2[1];
118
-
83
+ presets: presets
84
+ })),
85
+ _await$getBuilders2 = _slicedToArray(_await$getBuilders, 2),
86
+ previewBuilder = _await$getBuilders2[0],
87
+ managerBuilder = _await$getBuilders2[1];
119
88
  var _await$presets$apply = await presets.apply('core', undefined),
120
- renderer = _await$presets$apply.renderer;
121
-
89
+ renderer = _await$presets$apply.renderer;
122
90
  presets = await (0, _coreCommon.loadAllPresets)(_objectSpread({
123
91
  corePresets: [require.resolve('./presets/common-preset'), ...(managerBuilder.corePresets || []), ...(previewBuilder.corePresets || []), ...(renderer ? [(0, _coreCommon.resolveAddonName)(options.configDir, renderer, options)] : []), ...corePresets, require.resolve('./presets/babel-cache-preset')],
124
92
  overridePresets: previewBuilder.overridePresets
125
93
  }, options));
126
94
  var features = await presets.apply('features');
127
95
  _global.default.FEATURES = features;
128
-
129
96
  var fullOptions = _objectSpread(_objectSpread({}, options), {}, {
130
97
  presets: presets,
131
98
  features: features
132
99
  });
133
-
134
100
  var _await$storybookDevSe = await (0, _devServer.storybookDevServer)(fullOptions),
135
- address = _await$storybookDevSe.address,
136
- networkAddress = _await$storybookDevSe.networkAddress,
137
- managerResult = _await$storybookDevSe.managerResult,
138
- previewResult = _await$storybookDevSe.previewResult;
139
-
101
+ address = _await$storybookDevSe.address,
102
+ networkAddress = _await$storybookDevSe.networkAddress,
103
+ managerResult = _await$storybookDevSe.managerResult,
104
+ previewResult = _await$storybookDevSe.previewResult;
140
105
  var previewTotalTime = previewResult && previewResult.totalTime;
141
106
  var managerTotalTime = managerResult && managerResult.totalTime;
142
107
  var previewStats = previewResult && previewResult.stats;
143
108
  var managerStats = managerResult && managerResult.stats;
144
-
145
109
  if (options.webpackStatsJson) {
146
110
  var target = options.webpackStatsJson === true ? options.outputDir : options.webpackStatsJson;
147
111
  await (0, _outputStats.outputStats)(target, previewStats);
148
112
  }
149
-
150
113
  if (options.smokeTest) {
151
114
  var _managerStats$toJson, _previewStats$toJson;
152
-
153
115
  var warnings = [];
154
116
  warnings.push(...((managerStats === null || managerStats === void 0 ? void 0 : (_managerStats$toJson = managerStats.toJson()) === null || _managerStats$toJson === void 0 ? void 0 : _managerStats$toJson.warnings) || []));
155
117
  warnings.push(...((previewStats === null || previewStats === void 0 ? void 0 : (_previewStats$toJson = previewStats.toJson()) === null || _previewStats$toJson === void 0 ? void 0 : _previewStats$toJson.warnings) || []));
@@ -159,15 +121,15 @@ async function buildDevStandalone(options) {
159
121
  return !warning.message.includes(`compilation but it's unused`);
160
122
  }).filter(function (warning) {
161
123
  return !warning.message.includes(`Conflicting values for 'process.env.NODE_ENV'`);
162
- }); // eslint-disable-next-line no-console
124
+ });
163
125
 
126
+ // eslint-disable-next-line no-console
164
127
  console.log(problems.map(function (p) {
165
128
  return p.stack;
166
129
  }));
167
130
  process.exit(problems.length > 0 ? 1 : 0);
168
131
  return;
169
132
  }
170
-
171
133
  var name = frameworkName.split('@storybook/').length > 1 ? frameworkName.split('@storybook/')[1] : frameworkName;
172
134
  (0, _outputStartupInformation.outputStartupInformation)({
173
135
  updateInfo: versionCheck,
@@ -4,132 +4,89 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.buildStaticStandalone = buildStaticStandalone;
7
-
8
7
  var _chalk = _interopRequireDefault(require("chalk"));
9
-
10
8
  var _fsExtra = require("fs-extra");
11
-
12
9
  var _path = require("path");
13
-
14
10
  var _tsDedent = require("ts-dedent");
15
-
16
11
  var _global = _interopRequireDefault(require("global"));
17
-
18
12
  var _nodeLogger = require("@storybook/node-logger");
19
-
20
13
  var _telemetry = require("@storybook/telemetry");
21
-
22
14
  var _coreCommon = require("@storybook/core-common");
23
-
24
15
  var _outputStats = require("./utils/output-stats");
25
-
26
16
  var _copyAllStaticFiles = require("./utils/copy-all-static-files");
27
-
28
17
  var _getBuilders = require("./utils/get-builders");
29
-
30
18
  var _storiesJson = require("./utils/stories-json");
31
-
32
19
  var _metadata = require("./utils/metadata");
33
-
34
20
  var _StoryIndexGenerator = require("./utils/StoryIndexGenerator");
35
-
36
21
  var _summarizeIndex = require("./utils/summarizeIndex");
37
-
38
22
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
39
-
40
23
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
41
-
42
24
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
43
-
44
25
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
45
-
46
26
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
47
-
48
27
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
49
-
50
28
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
51
-
52
29
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
53
-
54
30
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
55
-
56
31
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
57
-
58
32
  async function buildStaticStandalone(options) {
59
33
  var _options$staticDir;
60
-
61
34
  /* eslint-disable no-param-reassign */
62
35
  options.configType = 'PRODUCTION';
63
-
64
36
  if (options.outputDir === '') {
65
37
  throw new Error("Won't remove current directory. Check your outputDir!");
66
38
  }
67
-
68
39
  if ((_options$staticDir = options.staticDir) !== null && _options$staticDir !== void 0 && _options$staticDir.includes('/')) {
69
40
  throw new Error("Won't copy root directory. Check your staticDirs!");
70
41
  }
71
-
72
42
  options.outputDir = (0, _path.isAbsolute)(options.outputDir) ? options.outputDir : (0, _path.join)(process.cwd(), options.outputDir);
73
43
  options.configDir = (0, _path.resolve)(options.configDir);
74
44
  /* eslint-enable no-param-reassign */
75
45
 
76
46
  _nodeLogger.logger.info((0, _chalk.default)`=> Cleaning outputDir: {cyan ${options.outputDir.replace(process.cwd(), '')}}`);
77
-
78
47
  if (options.outputDir === '/') {
79
48
  throw new Error("Won't remove directory '/'. Check your outputDir!");
80
49
  }
81
-
82
50
  await (0, _fsExtra.emptyDir)(options.outputDir);
83
51
  await (0, _fsExtra.ensureDir)(options.outputDir);
84
-
85
52
  var _loadMainConfig = (0, _coreCommon.loadMainConfig)(options),
86
- framework = _loadMainConfig.framework;
87
-
53
+ framework = _loadMainConfig.framework;
88
54
  var corePresets = [];
89
55
  var frameworkName = typeof framework === 'string' ? framework : framework === null || framework === void 0 ? void 0 : framework.name;
90
-
91
56
  if (frameworkName) {
92
57
  corePresets.push((0, _path.join)(frameworkName, 'preset'));
93
58
  } else {
94
59
  _nodeLogger.logger.warn(`you have not specified a framework in your ${options.configDir}/main.js`);
95
60
  }
96
-
97
61
  _nodeLogger.logger.info('=> Loading presets');
98
-
99
62
  var presets = await (0, _coreCommon.loadAllPresets)(_objectSpread({
100
63
  corePresets: [require.resolve('./presets/common-preset'), ...corePresets],
101
64
  overridePresets: []
102
65
  }, options));
103
-
104
66
  var _await$getBuilders = await (0, _getBuilders.getBuilders)(_objectSpread(_objectSpread({}, options), {}, {
105
- presets: presets
106
- })),
107
- _await$getBuilders2 = _slicedToArray(_await$getBuilders, 2),
108
- previewBuilder = _await$getBuilders2[0],
109
- managerBuilder = _await$getBuilders2[1];
110
-
67
+ presets: presets
68
+ })),
69
+ _await$getBuilders2 = _slicedToArray(_await$getBuilders, 2),
70
+ previewBuilder = _await$getBuilders2[0],
71
+ managerBuilder = _await$getBuilders2[1];
111
72
  var _await$presets$apply = await presets.apply('core', undefined),
112
- renderer = _await$presets$apply.renderer;
113
-
73
+ renderer = _await$presets$apply.renderer;
114
74
  presets = await (0, _coreCommon.loadAllPresets)(_objectSpread({
115
75
  corePresets: [require.resolve('./presets/common-preset'), ...(managerBuilder.corePresets || []), ...(previewBuilder.corePresets || []), ...(renderer ? [(0, _coreCommon.resolveAddonName)(options.configDir, renderer, options)] : []), ...corePresets, require.resolve('./presets/babel-cache-preset')],
116
76
  overridePresets: previewBuilder.overridePresets || []
117
77
  }, options));
118
-
119
78
  var _await$Promise$all = await Promise.all([presets.apply('features'), presets.apply('core'), presets.apply('staticDirs'), presets.apply('storyIndexers', []), presets.apply('stories'), presets.apply('docs', {})]),
120
- _await$Promise$all2 = _slicedToArray(_await$Promise$all, 6),
121
- features = _await$Promise$all2[0],
122
- core = _await$Promise$all2[1],
123
- staticDirs = _await$Promise$all2[2],
124
- storyIndexers = _await$Promise$all2[3],
125
- stories = _await$Promise$all2[4],
126
- docsOptions = _await$Promise$all2[5];
127
-
79
+ _await$Promise$all2 = _slicedToArray(_await$Promise$all, 6),
80
+ features = _await$Promise$all2[0],
81
+ core = _await$Promise$all2[1],
82
+ staticDirs = _await$Promise$all2[2],
83
+ storyIndexers = _await$Promise$all2[3],
84
+ stories = _await$Promise$all2[4],
85
+ docsOptions = _await$Promise$all2[5];
128
86
  var fullOptions = _objectSpread(_objectSpread({}, options), {}, {
129
87
  presets: presets,
130
88
  features: features
131
89
  });
132
-
133
90
  if (staticDirs && options.staticDir) {
134
91
  throw new Error((0, _tsDedent.dedent)`
135
92
  Conflict when trying to read staticDirs:
@@ -139,26 +96,21 @@ async function buildStaticStandalone(options) {
139
96
  Choose one of them, but not both.
140
97
  `);
141
98
  }
142
-
143
99
  var effects = [];
144
100
  _global.default.FEATURES = features;
145
101
  await managerBuilder.build({
146
102
  startTime: process.hrtime(),
147
103
  options: fullOptions
148
104
  });
149
-
150
105
  if (staticDirs) {
151
106
  effects.push((0, _copyAllStaticFiles.copyAllStaticFilesRelativeToMain)(staticDirs, options.outputDir, options.configDir));
152
107
  }
153
-
154
108
  if (options.staticDir) {
155
109
  effects.push((0, _copyAllStaticFiles.copyAllStaticFiles)(options.staticDir, options.outputDir));
156
110
  }
157
-
158
111
  var coreServerPublicDir = (0, _path.join)((0, _path.dirname)(require.resolve('@storybook/core-server/package.json')), 'public');
159
112
  effects.push((0, _fsExtra.copy)(coreServerPublicDir, options.outputDir));
160
113
  var initializedStoryIndexGenerator = Promise.resolve(undefined);
161
-
162
114
  if ((features !== null && features !== void 0 && features.buildStoriesJson || features !== null && features !== void 0 && features.storyStoreV7) && !options.ignorePreview) {
163
115
  var workingDir = process.cwd();
164
116
  var directories = {
@@ -178,7 +130,6 @@ async function buildStaticStandalone(options) {
178
130
  effects.push((0, _storiesJson.extractStoriesJson)((0, _path.join)(options.outputDir, 'stories.json'), initializedStoryIndexGenerator, _storiesJson.convertToIndexV3));
179
131
  effects.push((0, _storiesJson.extractStoriesJson)((0, _path.join)(options.outputDir, 'index.json'), initializedStoryIndexGenerator));
180
132
  }
181
-
182
133
  if (!(core !== null && core !== void 0 && core.disableTelemetry)) {
183
134
  effects.push(initializedStoryIndexGenerator.then(async function (generator) {
184
135
  var storyIndex = await (generator === null || generator === void 0 ? void 0 : generator.getIndex());
@@ -190,19 +141,15 @@ async function buildStaticStandalone(options) {
190
141
  });
191
142
  }));
192
143
  }
193
-
194
144
  if (!(core !== null && core !== void 0 && core.disableProjectJson)) {
195
145
  effects.push((0, _metadata.extractStorybookMetadata)((0, _path.join)(options.outputDir, 'project.json'), options.configDir));
196
146
  }
197
-
198
147
  if (options.debugWebpack) {
199
148
  (0, _coreCommon.logConfig)('Preview webpack config', await previewBuilder.getConfig(fullOptions));
200
149
  }
201
-
202
150
  if (options.ignorePreview) {
203
151
  _nodeLogger.logger.info(`=> Not building preview`);
204
152
  }
205
-
206
153
  await Promise.all([...(options.ignorePreview ? [] : [previewBuilder.build({
207
154
  startTime: process.hrtime(),
208
155
  options: fullOptions
@@ -212,6 +159,5 @@ async function buildStaticStandalone(options) {
212
159
  await (0, _outputStats.outputStats)(target, previewStats);
213
160
  }
214
161
  })]), ...effects]);
215
-
216
162
  _nodeLogger.logger.info(`=> Output directory: ${options.outputDir}`);
217
163
  }
@@ -1,49 +1,34 @@
1
1
  "use strict";
2
2
 
3
3
  require("jest-specific-snapshot");
4
-
5
4
  var _path = _interopRequireDefault(require("path"));
6
-
7
5
  var _fs = require("fs");
8
-
9
6
  var _os = _interopRequireDefault(require("os"));
10
-
11
7
  var _util = require("util");
12
-
13
8
  var _coreCommon = require("@storybook/core-common");
14
-
15
9
  var _builderWebpack = require("@storybook/builder-webpack5");
16
-
17
10
  var _builderManager = require("@storybook/builder-manager");
18
-
19
11
  var _readPkgUp = require("read-pkg-up");
20
-
21
12
  var _buildDev = require("./build-dev");
22
-
23
13
  var _buildStatic = require("./build-static");
24
-
25
14
  var _outputStats = require("./utils/output-stats");
26
-
27
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
28
-
29
16
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
30
-
31
17
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
32
-
33
18
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
34
-
35
19
  // @ts-expect-error (not strict)
36
20
  var _global = global,
37
- SNAPSHOT_OS = _global.SNAPSHOT_OS;
21
+ SNAPSHOT_OS = _global.SNAPSHOT_OS;
38
22
  var mkdtemp = (0, _util.promisify)(_fs.mkdtemp);
39
-
40
23
  var _readUpSync = (0, _readPkgUp.sync)({
41
- cwd: __dirname
42
- }),
43
- packageJson = _readUpSync.packageJson; // this only applies to this file
24
+ cwd: __dirname
25
+ }),
26
+ packageJson = _readUpSync.packageJson;
44
27
 
28
+ // this only applies to this file
29
+ jest.setTimeout(10000);
45
30
 
46
- jest.setTimeout(10000); // FIXME: this doesn't work
31
+ // FIXME: this doesn't work
47
32
 
48
33
  jest.mock('webpack', function () {
49
34
  var value = jest.fn(function () {
@@ -102,21 +87,18 @@ jest.mock('fs-extra', function () {
102
87
  });
103
88
  jest.mock('./utils/StoryIndexGenerator', function () {
104
89
  var _jest$requireActual = jest.requireActual('./utils/StoryIndexGenerator'),
105
- StoryIndexGenerator = _jest$requireActual.StoryIndexGenerator;
106
-
90
+ StoryIndexGenerator = _jest$requireActual.StoryIndexGenerator;
107
91
  return {
108
92
  StoryIndexGenerator: class extends StoryIndexGenerator {
109
93
  initialize() {
110
94
  return Promise.resolve(undefined);
111
95
  }
112
-
113
96
  getIndex() {
114
97
  return {
115
98
  stories: {},
116
99
  v: 3
117
100
  };
118
101
  }
119
-
120
102
  }
121
103
  };
122
104
  });
@@ -127,9 +109,10 @@ jest.mock('./utils/stories-json', function () {
127
109
  },
128
110
  useStoriesJson: function () {}
129
111
  };
130
- }); // we're not in the right directory for auto-title to work, so just
131
- // stub it out
112
+ });
132
113
 
114
+ // we're not in the right directory for auto-title to work, so just
115
+ // stub it out
133
116
  jest.mock('@storybook/store', function () {
134
117
  var actualStore = jest.requireActual('@storybook/store');
135
118
  return _objectSpread(_objectSpread({}, actualStore), {}, {
@@ -180,8 +163,8 @@ jest.mock('./utils/open-in-browser', function () {
180
163
  var cache = (0, _coreCommon.createFileSystemCache)({
181
164
  basePath: (0, _coreCommon.resolvePathInStorybookCache)('dev-server'),
182
165
  ns: 'storybook-test' // Optional. A grouping namespace for items.
183
-
184
166
  });
167
+
185
168
  var managerOnly = false;
186
169
  var baseOptions = {
187
170
  ignorePreview: managerOnly,
@@ -197,49 +180,39 @@ var baseOptions = {
197
180
  var ROOT = (0, _coreCommon.getProjectRoot)();
198
181
  var CWD = process.cwd();
199
182
  var NODE_MODULES = /.*node_modules/g;
200
-
201
183
  var cleanRoots = function (obj) {
202
184
  if (!obj) return obj;
203
185
  if (typeof obj === 'string') return obj.replace(CWD, 'CWD').replace(ROOT, 'ROOT').replace(NODE_MODULES, 'NODE_MODULES');
204
186
  if (Array.isArray(obj)) return obj.map(cleanRoots);
205
187
  if (obj instanceof RegExp) return cleanRoots(obj.toString());
206
-
207
188
  if (typeof obj === 'object') {
208
189
  return Object.fromEntries(Object.entries(obj).map(function ([key, val]) {
209
190
  if (key === 'version' && typeof val === 'string') {
210
191
  return [key, '*'];
211
192
  }
212
-
213
193
  return [key, cleanRoots(val)];
214
194
  }));
215
195
  }
216
-
217
196
  return obj;
218
197
  };
219
-
220
198
  var getConfig = function (fn, name) {
221
199
  var call = fn.mock.calls.find(function (c) {
222
200
  return c[0].name === name;
223
201
  });
224
-
225
202
  if (!call) {
226
203
  return null;
227
204
  }
228
-
229
205
  return call[0];
230
206
  };
231
-
232
207
  var prepareSnap = function (get, name) {
233
208
  var config = getConfig(get(), name);
234
-
235
209
  if (!config) {
236
210
  return null;
237
211
  }
238
-
239
212
  var keys = Object.keys(config);
240
213
  var module = config.module,
241
- entry = config.entry,
242
- plugins = config.plugins;
214
+ entry = config.entry,
215
+ plugins = config.plugins;
243
216
  return cleanRoots({
244
217
  keys: keys,
245
218
  module: module,
@@ -249,13 +222,12 @@ var prepareSnap = function (get, name) {
249
222
  })
250
223
  });
251
224
  };
252
-
253
225
  var snap = function (name) {
254
226
  return `__snapshots__/${name}`;
255
- }; // FIXME: we no longer have test cases
256
- // eslint-disable-next-line jest/no-disabled-tests
257
-
227
+ };
258
228
 
229
+ // FIXME: we no longer have test cases
230
+ // eslint-disable-next-line jest/no-disabled-tests
259
231
  describe.skip('FIXME', function () {
260
232
  // @ts-expect-error (not strict)
261
233
  describe.each([[]])('%s', function (example) {
@@ -273,7 +245,6 @@ describe.skip('FIXME', function () {
273
245
  managerCache: component === 'preview',
274
246
  packageJson: packageJson
275
247
  });
276
-
277
248
  await builder(options);
278
249
  var config = prepareSnap(executor.get, component);
279
250
  expect(config).toMatchSpecificSnapshot(snap(`${example}_${component}-${mode}-${SNAPSHOT_OS}`));
@@ -281,35 +252,32 @@ describe.skip('FIXME', function () {
281
252
  });
282
253
  });
283
254
  });
284
-
285
255
  var progressPlugin = function (config) {
286
256
  return config.plugins.find(function (p) {
287
257
  return p.constructor.name === 'ProgressPlugin';
288
258
  });
289
259
  };
290
-
291
260
  describe('dev cli flags', function () {
292
261
  beforeEach(async function () {
293
262
  jest.clearAllMocks();
294
263
  await cache.clear();
295
264
  });
296
-
297
265
  var cliOptions = _objectSpread(_objectSpread({}, baseOptions), {}, {
298
266
  packageJson: packageJson
299
- }); // eslint-disable-next-line jest/no-disabled-tests
300
-
267
+ });
301
268
 
269
+ // eslint-disable-next-line jest/no-disabled-tests
302
270
  it.skip('baseline', async function () {
303
271
  await (0, _buildDev.buildDevStandalone)(cliOptions);
304
272
  var config = getConfig(_builderWebpack.executor.get, 'preview');
305
273
  expect(progressPlugin(config)).toBeTruthy();
306
- }); // eslint-disable-next-line jest/no-disabled-tests
274
+ });
307
275
 
276
+ // eslint-disable-next-line jest/no-disabled-tests
308
277
  it.skip('--quiet', async function () {
309
278
  var options = _objectSpread(_objectSpread({}, cliOptions), {}, {
310
279
  quiet: true
311
280
  });
312
-
313
281
  await (0, _buildDev.buildDevStandalone)(options);
314
282
  var config = getConfig(_builderWebpack.executor.get, 'preview');
315
283
  expect(progressPlugin(config)).toBeFalsy();
@@ -328,7 +296,6 @@ describe('dev cli flags', function () {
328
296
  var optionsWithInvalidDir = _objectSpread(_objectSpread({}, cliOptions), {}, {
329
297
  outputDir: outputDir
330
298
  });
331
-
332
299
  it('production mode', async function () {
333
300
  expect.assertions(1);
334
301
  await expect((0, _buildStatic.buildStaticStandalone)(optionsWithInvalidDir)).rejects.toThrow(expectedErrorMessage);
@@ -338,10 +305,9 @@ describe('dev cli flags', function () {
338
305
  var optionsWithInvalidStaticDir = _objectSpread(_objectSpread({}, cliOptions), {}, {
339
306
  staticDir: ['/']
340
307
  });
341
-
342
308
  it('production mode', async function () {
343
- expect.assertions(1); // @ts-expect-error (not strict)
344
-
309
+ expect.assertions(1);
310
+ // @ts-expect-error (not strict)
345
311
  await expect((0, _buildStatic.buildStaticStandalone)(optionsWithInvalidStaticDir)).rejects.toThrow("Won't copy root directory. Check your staticDirs!");
346
312
  });
347
313
  });
@@ -351,12 +317,10 @@ describe('build cli flags', function () {
351
317
  jest.clearAllMocks();
352
318
  await cache.clear();
353
319
  });
354
-
355
320
  var cliOptions = _objectSpread(_objectSpread({}, baseOptions), {}, {
356
321
  outputDir: `${__dirname}/storybook-static`,
357
322
  packageJson: packageJson
358
323
  });
359
-
360
324
  it('does not call output-stats', async function () {
361
325
  await (0, _buildStatic.buildStaticStandalone)(cliOptions);
362
326
  expect(_outputStats.outputStats).not.toHaveBeenCalled();