@storybook/builder-webpack5 7.0.0-alpha.54 → 7.0.0-alpha.56

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.
@@ -723,6 +723,44 @@ interface Parameters {
723
723
  [name: string]: any;
724
724
  }
725
725
 
726
+ interface StoriesSpecifier {
727
+ /**
728
+ * When auto-titling, what to prefix all generated titles with (default: '')
729
+ */
730
+ titlePrefix?: string;
731
+ /**
732
+ * Where to start looking for story files
733
+ */
734
+ directory: string;
735
+ /**
736
+ * What does the filename of a story file look like?
737
+ * (a glob, relative to directory, no leading `./`)
738
+ * If unset, we use `** / *.@(mdx|stories.@(mdx|tsx|ts|jsx|js))` (no spaces)
739
+ */
740
+ files?: string;
741
+ }
742
+ type StoriesEntry = string | StoriesSpecifier;
743
+ interface IndexerOptions {
744
+ makeTitle: (userTitle?: string) => string;
745
+ }
746
+ interface IndexedStory {
747
+ id: string;
748
+ name: string;
749
+ tags?: Tag[];
750
+ parameters?: Parameters;
751
+ }
752
+ interface IndexedCSFFile {
753
+ meta: {
754
+ title?: string;
755
+ tags?: Tag[];
756
+ };
757
+ stories: IndexedStory[];
758
+ }
759
+ interface StoryIndexer {
760
+ test: RegExp;
761
+ indexer: (fileName: string, options: IndexerOptions) => Promise<IndexedCSFFile>;
762
+ }
763
+
726
764
  interface Options$1 {
727
765
  allowRegExp: boolean;
728
766
  allowFunction: boolean;
@@ -783,7 +821,7 @@ interface Presets {
783
821
  apply(extension: 'framework', config?: {}, args?: any): Promise<Preset>;
784
822
  apply(extension: 'babel', config?: {}, args?: any): Promise<TransformOptions>;
785
823
  apply(extension: 'entries', config?: [], args?: any): Promise<unknown>;
786
- apply(extension: 'stories', config?: [], args?: any): Promise<CoreCommon_StoriesEntry[]>;
824
+ apply(extension: 'stories', config?: [], args?: any): Promise<StoriesEntry[]>;
787
825
  apply(extension: 'managerEntries', config: [], args?: any): Promise<string[]>;
788
826
  apply(extension: 'refs', config?: [], args?: any): Promise<unknown>;
789
827
  apply(extension: 'core', config?: {}, args?: any): Promise<CoreConfig>;
@@ -888,26 +926,6 @@ interface Builder<Config, BuilderStats extends Stats = Stats> {
888
926
  corePresets?: string[];
889
927
  overridePresets?: string[];
890
928
  }
891
- interface CoreCommon_IndexerOptions {
892
- makeTitle: (userTitle?: string) => string;
893
- }
894
- interface CoreCommon_IndexedStory {
895
- id: string;
896
- name: string;
897
- tags?: Tag[];
898
- parameters?: Parameters;
899
- }
900
- interface CoreCommon_StoryIndex {
901
- meta: {
902
- title?: string;
903
- tags?: Tag[];
904
- };
905
- stories: CoreCommon_IndexedStory[];
906
- }
907
- interface CoreCommon_StoryIndexer {
908
- test: RegExp;
909
- indexer: (fileName: string, options: CoreCommon_IndexerOptions) => Promise<CoreCommon_StoryIndex>;
910
- }
911
929
  /**
912
930
  * Options for TypeScript usage within Storybook.
913
931
  */
@@ -925,23 +943,6 @@ interface TypescriptOptions {
925
943
  */
926
944
  skipBabel: boolean;
927
945
  }
928
- interface CoreCommon_StoriesSpecifier {
929
- /**
930
- * When auto-titling, what to prefix all generated titles with (default: '')
931
- */
932
- titlePrefix?: string;
933
- /**
934
- * Where to start looking for story files
935
- */
936
- directory: string;
937
- /**
938
- * What does the filename of a story file look like?
939
- * (a glob, relative to directory, no leading `./`)
940
- * If unset, we use `** / *.stories.@(mdx|tsx|ts|jsx|js)` (no spaces)
941
- */
942
- files?: string;
943
- }
944
- type CoreCommon_StoriesEntry = string | CoreCommon_StoriesSpecifier;
945
946
  type Preset = string | {
946
947
  name: string;
947
948
  options?: any;
@@ -1040,7 +1041,7 @@ interface StorybookConfig {
1040
1041
  *
1041
1042
  * @example `['./src/*.stories.@(j|t)sx?']`
1042
1043
  */
1043
- stories: CoreCommon_StoriesEntry[];
1044
+ stories: StoriesEntry[];
1044
1045
  /**
1045
1046
  * Framework, e.g. '@storybook/react', required in v7
1046
1047
  */
@@ -1074,7 +1075,7 @@ interface StorybookConfig {
1074
1075
  /**
1075
1076
  * Process CSF files for the story index.
1076
1077
  */
1077
- storyIndexers?: (indexers: CoreCommon_StoryIndexer[], options: Options) => CoreCommon_StoryIndexer[];
1078
+ storyIndexers?: (indexers: StoryIndexer[], options: Options) => StoryIndexer[];
1078
1079
  /**
1079
1080
  * Docs related features in index generation
1080
1081
  */
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import webpack__default, { Configuration, Stats } from 'webpack';
2
- import { O as Options$1, B as Builder } from './index.d-b6637b5c.js';
2
+ import { O as Options$1, B as Builder } from './index.d-3d30a6c5.js';
3
3
  import { StorybookConfig, Options, BuilderResult as BuilderResult$1 } from '@storybook/core-webpack';
4
4
  import ForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin';
5
5
  import 'file-system-cache';
@@ -1,6 +1,6 @@
1
1
  import * as webpack$1 from 'webpack';
2
2
  import { Configuration } from 'webpack';
3
- import { O as Options } from '../index.d-b6637b5c.js';
3
+ import { O as Options } from '../index.d-3d30a6c5.js';
4
4
  import 'file-system-cache';
5
5
  import '@babel/core';
6
6
  import 'express';
@@ -1 +1 @@
1
- "use strict";var te=Object.create;var w=Object.defineProperty;var re=Object.getOwnPropertyDescriptor;var oe=Object.getOwnPropertyNames;var se=Object.getPrototypeOf,ne=Object.prototype.hasOwnProperty;var ie=(e,t)=>{for(var n in t)w(e,n,{get:t[n],enumerable:!0})},x=(e,t,n,f)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of oe(t))!ne.call(e,c)&&c!==n&&w(e,c,{get:()=>t[c],enumerable:!(f=re(t,c))||f.enumerable});return e};var s=(e,t,n)=>(n=e!=null?te(se(e)):{},x(t||!e||!e.__esModule?w(n,"default",{value:e,enumerable:!0}):n,e)),ae=e=>x(w({},"__esModule",{value:!0}),e);var de={};ie(de,{babel:()=>ce,babelLoaderRef:()=>me,entries:()=>pe,previewMainTemplate:()=>ue,webpack:()=>le});module.exports=ae(de);var o=require("path"),m=require("webpack"),D=s(require("html-webpack-plugin")),L=s(require("case-sensitive-paths-webpack-plugin")),$=s(require("terser-webpack-plugin")),M=s(require("webpack-virtual-modules")),B=s(require("fork-ts-checker-webpack-plugin")),r=require("@storybook/core-common"),k=require("@storybook/core-webpack");var N=require("@storybook/core-common"),q=(e,t)=>({test:t.skipBabel?/\.(mjs|jsx?)$/:/\.(mjs|tsx?|jsx?)$/,use:[{loader:require.resolve("babel-loader"),options:e}],include:[(0,N.getProjectRoot)()],exclude:/node_modules/});var E={global:(0,o.dirname)(require.resolve("global/package.json")),...["api","manager-api","components","router","theming"].reduce((e,t)=>({...e,[`@storybook/${t}`]:(0,o.dirname)(require.resolve(`@storybook/${t}/package.json`))}),{})},I=async e=>{var S;let{outputDir:t=(0,o.join)(".","public"),quiet:n,packageJson:f,configType:c,presets:a,previewUrl:A,babelOptions:W,typescriptOptions:v,features:h,serverChannelUrl:z}=e,p=c==="PRODUCTION",y=process.cwd(),[P,H,T,U,V,F,G,J,g,K]=await Promise.all([a.apply("core"),a.apply("frameworkOptions"),a.apply("env"),a.apply("logLevel",void 0),a.apply("previewHead"),a.apply("previewBody"),a.apply("previewMainTemplate"),a.apply("docs"),a.apply("entries",[],e),a.apply("stories",[],e)]),O=(0,r.normalizeStories)(K,{configDir:e.configDir,workingDir:y}),C=typeof P.builder=="string"?{}:((S=P.builder)==null?void 0:S.options)||{},_=[...(await a.apply("previewAnnotations",[],e)).map(i=>typeof i=="object"?i.absolute:i),(0,r.loadPreviewOrConfigFile)(e)].filter(Boolean),u={};if(h!=null&&h.storyStoreV7){let i="storybook-stories.js",d=(0,o.resolve)((0,o.join)(y,i)),j=!!C.lazyCompilation&&!p;u[d]=(0,k.toImportFn)(O,{needPipelinedImport:j});let l=(0,o.resolve)((0,o.join)(y,"storybook-config-entry.js"));u[l]=(0,r.handlebars)(await(0,r.readTemplate)(require.resolve("@storybook/builder-webpack5/templates/virtualModuleModernEntry.js.handlebars")),{storiesFilename:i,previewAnnotations:_}).replace(/\\/g,"\\\\"),g.push(l)}else{let i=await(0,r.getRendererName)(e),d=(0,o.resolve)((0,o.join)(y,"storybook-init-renderer-entry.js"));u[d]=`import '${i}';`,g.push(d);let j=await(0,r.readTemplate)((0,o.join)(__dirname,"..","..","templates","virtualModuleEntry.template.js"));if(_.forEach(l=>{if(!l)return;let b=E["@storybook/preview-api"],ee=E["@storybook/client-logger"],R=l.startsWith(".")?`${l.replace(/(\w)(\/|\\)/g,"$1-")}-generated-config-entry.js`:`${l}-generated-config-entry.js`;u[R]=(0,r.interpolate)(j,{previewAnnotationFilename:l,previewApi:b,clientLogger:ee}),g.push(R)}),O.length>0){let l=await(0,r.readTemplate)((0,o.join)(__dirname,"..","..","templates","virtualModuleStory.template.js")),b=(0,o.resolve)((0,o.join)(y,"generated-stories-entry.cjs"));u[b]=(0,r.interpolate)(l,{rendererName:i}).replace("'{{stories}}'",O.map(k.toRequireContextString).join(",")),g.push(b)}}let Y=v.check&&!v.skipBabel,Q=v.checkOptions||{},X=C.fsCache?{cache:{type:"filesystem"}}:{},Z=C.lazyCompilation&&!p?{lazyCompilation:{entries:!1}}:{};return{name:"preview",mode:p?"production":"development",bail:p,devtool:"cheap-module-source-map",entry:g,output:{path:(0,o.resolve)(process.cwd(),t),filename:p?"[name].[contenthash:8].iframe.bundle.js":"[name].iframe.bundle.js",publicPath:""},stats:{preset:"none",logging:"error"},watchOptions:{ignored:/node_modules/},externals:{...["addons","channel-postmessage","channel-websocket","channels","client-logger","core-events","preview-api"].reduce((i,d)=>({...i,[`@storybook/${d}`]:`__STORYBOOK_MODULE_${d.toUpperCase().replaceAll("-","_")}__`}),{})},ignoreWarnings:[{message:/export '\S+' was not found in 'global'/}],plugins:[Object.keys(u).length>0?new M.default(u):null,new D.default({filename:"iframe.html",chunksSortMode:"none",alwaysWriteToDisk:!0,inject:!1,template:G,templateParameters:{version:f.version,globals:{CONFIG_TYPE:c,LOGLEVEL:U,FRAMEWORK_OPTIONS:H,CHANNEL_OPTIONS:P.channelOptions,FEATURES:h,PREVIEW_URL:A,STORIES:O.map(i=>({...i,importPathMatcher:i.importPathMatcher.source})),DOCS_OPTIONS:J,SERVER_CHANNEL_URL:z},headHtmlSnippet:V,bodyHtmlSnippet:F},minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!0,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!0,useShortDoctype:!0}}),new m.DefinePlugin({...(0,r.stringifyProcessEnvs)(T),NODE_ENV:JSON.stringify(process.env.NODE_ENV)}),new m.ProvidePlugin({process:require.resolve("process/browser.js")}),p?null:new m.HotModuleReplacementPlugin,new L.default,n?null:new m.ProgressPlugin({}),Y?new B.default(Q):null].filter(Boolean),module:{rules:[{test:/\.m?js$/,type:"javascript/auto"},{test:/\.m?js$/,resolve:{fullySpecified:!1}},q(W,v),{test:/\.md$/,type:"asset/source"}]},resolve:{extensions:[".mjs",".js",".jsx",".ts",".tsx",".json",".cjs"],modules:["node_modules"].concat(T.NODE_PATH||[]),mainFields:["browser","module","main"].filter(Boolean),alias:E,fallback:{path:require.resolve("path-browserify"),assert:require.resolve("browser-assert"),util:require.resolve("util")},symlinks:!(0,r.isPreservingSymlinks)()},optimization:{splitChunks:{chunks:"all"},runtimeChunk:!0,sideEffects:!0,usedExports:p,moduleIds:"named",minimizer:p?[new $.default({parallel:!0,terserOptions:{sourceMap:!0,mangle:!1,keep_fnames:!0}})]:[]},performance:{hints:p?"warning":!1},...X,experiments:{...Z}}};var le=async(e,t)=>I(t),pe=async(e,t)=>{let n=[];return t.configType==="DEVELOPMENT"&&(n=n.concat(`${require.resolve("webpack-hot-middleware/client")}?reload=true&quiet=false&noInfo=${t.quiet}`)),n},ce=async(e,t)=>({...e,overrides:[...(e==null?void 0:e.overrides)||[],{test:/\.(story|stories).*$/,plugins:[require.resolve("babel-plugin-named-exports-order")]}]}),me=()=>require.resolve("babel-loader"),ue=()=>require.resolve("@storybook/builder-webpack5/templates/preview.ejs");0&&(module.exports={babel,babelLoaderRef,entries,previewMainTemplate,webpack});
1
+ "use strict";var re=Object.create;var k=Object.defineProperty;var oe=Object.getOwnPropertyDescriptor;var se=Object.getOwnPropertyNames;var ne=Object.getPrototypeOf,ie=Object.prototype.hasOwnProperty;var ae=(e,t)=>{for(var n in t)k(e,n,{get:t[n],enumerable:!0})},x=(e,t,n,g)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of se(t))!ie.call(e,c)&&c!==n&&k(e,c,{get:()=>t[c],enumerable:!(g=oe(t,c))||g.enumerable});return e};var s=(e,t,n)=>(n=e!=null?re(ne(e)):{},x(t||!e||!e.__esModule?k(n,"default",{value:e,enumerable:!0}):n,e)),le=e=>x(k({},"__esModule",{value:!0}),e);var ye={};ae(ye,{babel:()=>me,babelLoaderRef:()=>ue,entries:()=>ce,previewMainTemplate:()=>de,webpack:()=>pe});module.exports=le(ye);var o=require("path"),m=require("webpack"),D=s(require("html-webpack-plugin")),L=s(require("case-sensitive-paths-webpack-plugin")),M=s(require("terser-webpack-plugin")),$=s(require("webpack-virtual-modules")),I=s(require("fork-ts-checker-webpack-plugin")),B=require("@storybook/preview/globals"),r=require("@storybook/core-common"),w=require("@storybook/core-webpack");var N=require("@storybook/core-common"),q=(e,t)=>({test:t.skipBabel?/\.(mjs|jsx?)$/:/\.(mjs|tsx?|jsx?)$/,use:[{loader:require.resolve("babel-loader"),options:e}],include:[(0,N.getProjectRoot)()],exclude:/node_modules/});var E={global:(0,o.dirname)(require.resolve("global/package.json")),...["api","manager-api","components","router","theming"].reduce((e,t)=>({...e,[`@storybook/${t}`]:(0,o.dirname)(require.resolve(`@storybook/${t}/package.json`))}),{}),["@storybook/api"]:(0,o.dirname)(require.resolve("@storybook/manager-api/package.json"))},A=async e=>{var R;let{outputDir:t=(0,o.join)(".","public"),quiet:n,packageJson:g,configType:c,presets:a,previewUrl:W,babelOptions:z,typescriptOptions:f,features:v,serverChannelUrl:H}=e,p=c==="PRODUCTION",d=process.cwd(),[P,V,T,F,U,G,J,K,y,Y]=await Promise.all([a.apply("core"),a.apply("frameworkOptions"),a.apply("env"),a.apply("logLevel",void 0),a.apply("previewHead"),a.apply("previewBody"),a.apply("previewMainTemplate"),a.apply("docs"),a.apply("entries",[],e),a.apply("stories",[],e)]),b=(0,r.normalizeStories)(Y,{configDir:e.configDir,workingDir:d}),j=typeof P.builder=="string"?{}:((R=P.builder)==null?void 0:R.options)||{},S=[...(await a.apply("previewAnnotations",[],e)).map(i=>typeof i=="object"?i.absolute:i),(0,r.loadPreviewOrConfigFile)(e)].filter(Boolean),u={};if(v!=null&&v.storyStoreV7){let i="storybook-stories.js",h=(0,o.resolve)((0,o.join)(d,i)),C=!!j.lazyCompilation&&!p;u[h]=(0,w.toImportFn)(b,{needPipelinedImport:C});let l=(0,o.resolve)((0,o.join)(d,"storybook-config-entry.js"));u[l]=(0,r.handlebars)(await(0,r.readTemplate)(require.resolve("@storybook/builder-webpack5/templates/virtualModuleModernEntry.js.handlebars")),{storiesFilename:i,previewAnnotations:S}).replace(/\\/g,"\\\\"),y.push(l)}else{let i=await(0,r.getRendererName)(e),h=(0,o.resolve)((0,o.join)(d,"storybook-init-renderer-entry.js"));u[h]=`import '${i}';`,y.push(h);let C=await(0,r.readTemplate)((0,o.join)(__dirname,"..","..","templates","virtualModuleEntry.template.js"));if(S.forEach(l=>{if(!l)return;let O=E["@storybook/preview-api"],te=E["@storybook/client-logger"],_=l.startsWith(".")?`${l.replace(/(\w)(\/|\\)/g,"$1-")}-generated-config-entry.js`:`${l}-generated-config-entry.js`;u[_]=(0,r.interpolate)(C,{previewAnnotationFilename:l,previewApi:O,clientLogger:te}),y.push(_)}),b.length>0){let l=await(0,r.readTemplate)((0,o.join)(__dirname,"..","..","templates","virtualModuleStory.template.js")),O=(0,o.resolve)((0,o.join)(d,"generated-stories-entry.cjs"));u[O]=(0,r.interpolate)(l,{rendererName:i}).replace("'{{stories}}'",b.map(w.toRequireContextString).join(",")),y.push(O)}}let Q=f.check&&!f.skipBabel,X=f.checkOptions||{},Z=j.fsCache?{cache:{type:"filesystem"}}:{},ee=j.lazyCompilation&&!p?{lazyCompilation:{entries:!1}}:{};return{name:"preview",mode:p?"production":"development",bail:p,devtool:"cheap-module-source-map",entry:y,output:{path:(0,o.resolve)(process.cwd(),t),filename:p?"[name].[contenthash:8].iframe.bundle.js":"[name].iframe.bundle.js",publicPath:""},stats:{preset:"none",logging:"error"},watchOptions:{ignored:/node_modules/},externals:B.globals,ignoreWarnings:[{message:/export '\S+' was not found in 'global'/}],plugins:[Object.keys(u).length>0?new $.default(u):null,new D.default({filename:"iframe.html",chunksSortMode:"none",alwaysWriteToDisk:!0,inject:!1,template:J,templateParameters:{version:g.version,globals:{CONFIG_TYPE:c,LOGLEVEL:F,FRAMEWORK_OPTIONS:V,CHANNEL_OPTIONS:P.channelOptions,FEATURES:v,PREVIEW_URL:W,STORIES:b.map(i=>({...i,importPathMatcher:i.importPathMatcher.source})),DOCS_OPTIONS:K,SERVER_CHANNEL_URL:H},headHtmlSnippet:U,bodyHtmlSnippet:G},minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!0,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!0,useShortDoctype:!0}}),new m.DefinePlugin({...(0,r.stringifyProcessEnvs)(T),NODE_ENV:JSON.stringify(process.env.NODE_ENV)}),new m.ProvidePlugin({process:require.resolve("process/browser.js")}),p?null:new m.HotModuleReplacementPlugin,new L.default,n?null:new m.ProgressPlugin({}),Q?new I.default(X):null].filter(Boolean),module:{rules:[{test:/\.m?js$/,type:"javascript/auto"},{test:/\.m?js$/,resolve:{fullySpecified:!1}},q(z,f),{test:/\.md$/,type:"asset/source"}]},resolve:{extensions:[".mjs",".js",".jsx",".ts",".tsx",".json",".cjs"],modules:["node_modules"].concat(T.NODE_PATH||[]),mainFields:["browser","module","main"].filter(Boolean),alias:E,fallback:{path:require.resolve("path-browserify"),assert:require.resolve("browser-assert"),util:require.resolve("util")},symlinks:!(0,r.isPreservingSymlinks)()},optimization:{splitChunks:{chunks:"all"},runtimeChunk:!0,sideEffects:!0,usedExports:p,moduleIds:"named",minimizer:p?[new M.default({parallel:!0,terserOptions:{sourceMap:!0,mangle:!1,keep_fnames:!0}})]:[]},performance:{hints:p?"warning":!1},...Z,experiments:{...ee}}};var pe=async(e,t)=>A(t),ce=async(e,t)=>{let n=[];return t.configType==="DEVELOPMENT"&&(n=n.concat(`${require.resolve("webpack-hot-middleware/client")}?reload=true&quiet=false&noInfo=${t.quiet}`)),n},me=async(e,t)=>({...e,overrides:[...(e==null?void 0:e.overrides)||[],{test:/\.(story|stories).*$/,plugins:[require.resolve("babel-plugin-named-exports-order")]}]}),ue=()=>require.resolve("babel-loader"),de=()=>require.resolve("@storybook/builder-webpack5/templates/preview.ejs");0&&(module.exports={babel,babelLoaderRef,entries,previewMainTemplate,webpack});
@@ -1 +1 @@
1
- import{__require}from"../chunk-H7QDQLD3.mjs";import{dirname,join,resolve}from"path";import{DefinePlugin,HotModuleReplacementPlugin,ProgressPlugin,ProvidePlugin}from"webpack";import HtmlWebpackPlugin from"html-webpack-plugin";import CaseSensitivePathsPlugin from"case-sensitive-paths-webpack-plugin";import TerserWebpackPlugin from"terser-webpack-plugin";import VirtualModulePlugin from"webpack-virtual-modules";import ForkTsCheckerWebpackPlugin from"fork-ts-checker-webpack-plugin";import{getRendererName,stringifyProcessEnvs,handlebars,interpolate,normalizeStories,readTemplate,loadPreviewOrConfigFile,isPreservingSymlinks}from"@storybook/core-common";import{toRequireContextString,toImportFn}from"@storybook/core-webpack";import{getProjectRoot}from"@storybook/core-common";var createBabelLoader=(options,typescriptOptions)=>({test:typescriptOptions.skipBabel?/\.(mjs|jsx?)$/:/\.(mjs|tsx?|jsx?)$/,use:[{loader:__require.resolve("babel-loader"),options}],include:[getProjectRoot()],exclude:/node_modules/});var storybookPaths={global:dirname(__require.resolve("global/package.json")),...["api","manager-api","components","router","theming"].reduce((acc,sbPackage)=>({...acc,[`@storybook/${sbPackage}`]:dirname(__require.resolve(`@storybook/${sbPackage}/package.json`))}),{})},iframe_webpack_config_default=async options=>{let{outputDir=join(".","public"),quiet,packageJson,configType,presets,previewUrl,babelOptions,typescriptOptions,features,serverChannelUrl}=options,isProd=configType==="PRODUCTION",workingDir=process.cwd(),[coreOptions,frameworkOptions,envs,logLevel,headHtmlSnippet,bodyHtmlSnippet,template,docsOptions,entries2,nonNormalizedStories]=await Promise.all([presets.apply("core"),presets.apply("frameworkOptions"),presets.apply("env"),presets.apply("logLevel",void 0),presets.apply("previewHead"),presets.apply("previewBody"),presets.apply("previewMainTemplate"),presets.apply("docs"),presets.apply("entries",[],options),presets.apply("stories",[],options)]),stories=normalizeStories(nonNormalizedStories,{configDir:options.configDir,workingDir}),builderOptions=typeof coreOptions.builder=="string"?{}:coreOptions.builder?.options||{},previewAnnotations=[...(await presets.apply("previewAnnotations",[],options)).map(entry=>typeof entry=="object"?entry.absolute:entry),loadPreviewOrConfigFile(options)].filter(Boolean),virtualModuleMapping={};if(features?.storyStoreV7){let storiesFilename="storybook-stories.js",storiesPath=resolve(join(workingDir,storiesFilename)),needPipelinedImport=!!builderOptions.lazyCompilation&&!isProd;virtualModuleMapping[storiesPath]=toImportFn(stories,{needPipelinedImport});let configEntryPath=resolve(join(workingDir,"storybook-config-entry.js"));virtualModuleMapping[configEntryPath]=handlebars(await readTemplate(__require.resolve("@storybook/builder-webpack5/templates/virtualModuleModernEntry.js.handlebars")),{storiesFilename,previewAnnotations}).replace(/\\/g,"\\\\"),entries2.push(configEntryPath)}else{let rendererName=await getRendererName(options),rendererInitEntry=resolve(join(workingDir,"storybook-init-renderer-entry.js"));virtualModuleMapping[rendererInitEntry]=`import '${rendererName}';`,entries2.push(rendererInitEntry);let entryTemplate=await readTemplate(join(__dirname,"..","..","templates","virtualModuleEntry.template.js"));if(previewAnnotations.forEach(previewAnnotationFilename=>{if(!previewAnnotationFilename)return;let previewApi=storybookPaths["@storybook/preview-api"],clientLogger=storybookPaths["@storybook/client-logger"],entryFilename=previewAnnotationFilename.startsWith(".")?`${previewAnnotationFilename.replace(/(\w)(\/|\\)/g,"$1-")}-generated-config-entry.js`:`${previewAnnotationFilename}-generated-config-entry.js`;virtualModuleMapping[entryFilename]=interpolate(entryTemplate,{previewAnnotationFilename,previewApi,clientLogger}),entries2.push(entryFilename)}),stories.length>0){let storyTemplate=await readTemplate(join(__dirname,"..","..","templates","virtualModuleStory.template.js")),storiesFilename=resolve(join(workingDir,"generated-stories-entry.cjs"));virtualModuleMapping[storiesFilename]=interpolate(storyTemplate,{rendererName}).replace("'{{stories}}'",stories.map(toRequireContextString).join(",")),entries2.push(storiesFilename)}}let shouldCheckTs=typescriptOptions.check&&!typescriptOptions.skipBabel,tsCheckOptions=typescriptOptions.checkOptions||{},cacheConfig=builderOptions.fsCache?{cache:{type:"filesystem"}}:{},lazyCompilationConfig=builderOptions.lazyCompilation&&!isProd?{lazyCompilation:{entries:!1}}:{};return{name:"preview",mode:isProd?"production":"development",bail:isProd,devtool:"cheap-module-source-map",entry:entries2,output:{path:resolve(process.cwd(),outputDir),filename:isProd?"[name].[contenthash:8].iframe.bundle.js":"[name].iframe.bundle.js",publicPath:""},stats:{preset:"none",logging:"error"},watchOptions:{ignored:/node_modules/},externals:{...["addons","channel-postmessage","channel-websocket","channels","client-logger","core-events","preview-api"].reduce((acc,sbPackage)=>({...acc,[`@storybook/${sbPackage}`]:`__STORYBOOK_MODULE_${sbPackage.toUpperCase().replaceAll("-","_")}__`}),{})},ignoreWarnings:[{message:/export '\S+' was not found in 'global'/}],plugins:[Object.keys(virtualModuleMapping).length>0?new VirtualModulePlugin(virtualModuleMapping):null,new HtmlWebpackPlugin({filename:"iframe.html",chunksSortMode:"none",alwaysWriteToDisk:!0,inject:!1,template,templateParameters:{version:packageJson.version,globals:{CONFIG_TYPE:configType,LOGLEVEL:logLevel,FRAMEWORK_OPTIONS:frameworkOptions,CHANNEL_OPTIONS:coreOptions.channelOptions,FEATURES:features,PREVIEW_URL:previewUrl,STORIES:stories.map(specifier=>({...specifier,importPathMatcher:specifier.importPathMatcher.source})),DOCS_OPTIONS:docsOptions,SERVER_CHANNEL_URL:serverChannelUrl},headHtmlSnippet,bodyHtmlSnippet},minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!0,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!0,useShortDoctype:!0}}),new DefinePlugin({...stringifyProcessEnvs(envs),NODE_ENV:JSON.stringify(process.env.NODE_ENV)}),new ProvidePlugin({process:__require.resolve("process/browser.js")}),isProd?null:new HotModuleReplacementPlugin,new CaseSensitivePathsPlugin,quiet?null:new ProgressPlugin({}),shouldCheckTs?new ForkTsCheckerWebpackPlugin(tsCheckOptions):null].filter(Boolean),module:{rules:[{test:/\.m?js$/,type:"javascript/auto"},{test:/\.m?js$/,resolve:{fullySpecified:!1}},createBabelLoader(babelOptions,typescriptOptions),{test:/\.md$/,type:"asset/source"}]},resolve:{extensions:[".mjs",".js",".jsx",".ts",".tsx",".json",".cjs"],modules:["node_modules"].concat(envs.NODE_PATH||[]),mainFields:["browser","module","main"].filter(Boolean),alias:storybookPaths,fallback:{path:__require.resolve("path-browserify"),assert:__require.resolve("browser-assert"),util:__require.resolve("util")},symlinks:!isPreservingSymlinks()},optimization:{splitChunks:{chunks:"all"},runtimeChunk:!0,sideEffects:!0,usedExports:isProd,moduleIds:"named",minimizer:isProd?[new TerserWebpackPlugin({parallel:!0,terserOptions:{sourceMap:!0,mangle:!1,keep_fnames:!0}})]:[]},performance:{hints:isProd?"warning":!1},...cacheConfig,experiments:{...lazyCompilationConfig}}};var webpack=async(_,options)=>iframe_webpack_config_default(options),entries=async(_,options)=>{let result=[];return options.configType==="DEVELOPMENT"&&(result=result.concat(`${__require.resolve("webpack-hot-middleware/client")}?reload=true&quiet=false&noInfo=${options.quiet}`)),result},babel=async(config,options)=>({...config,overrides:[...config?.overrides||[],{test:/\.(story|stories).*$/,plugins:[__require.resolve("babel-plugin-named-exports-order")]}]}),babelLoaderRef=()=>__require.resolve("babel-loader"),previewMainTemplate=()=>__require.resolve("@storybook/builder-webpack5/templates/preview.ejs");export{babel,babelLoaderRef,entries,previewMainTemplate,webpack};
1
+ import{__require}from"../chunk-H7QDQLD3.mjs";import{dirname,join,resolve}from"path";import{DefinePlugin,HotModuleReplacementPlugin,ProgressPlugin,ProvidePlugin}from"webpack";import HtmlWebpackPlugin from"html-webpack-plugin";import CaseSensitivePathsPlugin from"case-sensitive-paths-webpack-plugin";import TerserWebpackPlugin from"terser-webpack-plugin";import VirtualModulePlugin from"webpack-virtual-modules";import ForkTsCheckerWebpackPlugin from"fork-ts-checker-webpack-plugin";import{globals}from"@storybook/preview/globals";import{getRendererName,stringifyProcessEnvs,handlebars,interpolate,normalizeStories,readTemplate,loadPreviewOrConfigFile,isPreservingSymlinks}from"@storybook/core-common";import{toRequireContextString,toImportFn}from"@storybook/core-webpack";import{getProjectRoot}from"@storybook/core-common";var createBabelLoader=(options,typescriptOptions)=>({test:typescriptOptions.skipBabel?/\.(mjs|jsx?)$/:/\.(mjs|tsx?|jsx?)$/,use:[{loader:__require.resolve("babel-loader"),options}],include:[getProjectRoot()],exclude:/node_modules/});var storybookPaths={global:dirname(__require.resolve("global/package.json")),...["api","manager-api","components","router","theming"].reduce((acc,sbPackage)=>({...acc,[`@storybook/${sbPackage}`]:dirname(__require.resolve(`@storybook/${sbPackage}/package.json`))}),{}),["@storybook/api"]:dirname(__require.resolve("@storybook/manager-api/package.json"))},iframe_webpack_config_default=async options=>{let{outputDir=join(".","public"),quiet,packageJson,configType,presets,previewUrl,babelOptions,typescriptOptions,features,serverChannelUrl}=options,isProd=configType==="PRODUCTION",workingDir=process.cwd(),[coreOptions,frameworkOptions,envs,logLevel,headHtmlSnippet,bodyHtmlSnippet,template,docsOptions,entries2,nonNormalizedStories]=await Promise.all([presets.apply("core"),presets.apply("frameworkOptions"),presets.apply("env"),presets.apply("logLevel",void 0),presets.apply("previewHead"),presets.apply("previewBody"),presets.apply("previewMainTemplate"),presets.apply("docs"),presets.apply("entries",[],options),presets.apply("stories",[],options)]),stories=normalizeStories(nonNormalizedStories,{configDir:options.configDir,workingDir}),builderOptions=typeof coreOptions.builder=="string"?{}:coreOptions.builder?.options||{},previewAnnotations=[...(await presets.apply("previewAnnotations",[],options)).map(entry=>typeof entry=="object"?entry.absolute:entry),loadPreviewOrConfigFile(options)].filter(Boolean),virtualModuleMapping={};if(features?.storyStoreV7){let storiesFilename="storybook-stories.js",storiesPath=resolve(join(workingDir,storiesFilename)),needPipelinedImport=!!builderOptions.lazyCompilation&&!isProd;virtualModuleMapping[storiesPath]=toImportFn(stories,{needPipelinedImport});let configEntryPath=resolve(join(workingDir,"storybook-config-entry.js"));virtualModuleMapping[configEntryPath]=handlebars(await readTemplate(__require.resolve("@storybook/builder-webpack5/templates/virtualModuleModernEntry.js.handlebars")),{storiesFilename,previewAnnotations}).replace(/\\/g,"\\\\"),entries2.push(configEntryPath)}else{let rendererName=await getRendererName(options),rendererInitEntry=resolve(join(workingDir,"storybook-init-renderer-entry.js"));virtualModuleMapping[rendererInitEntry]=`import '${rendererName}';`,entries2.push(rendererInitEntry);let entryTemplate=await readTemplate(join(__dirname,"..","..","templates","virtualModuleEntry.template.js"));if(previewAnnotations.forEach(previewAnnotationFilename=>{if(!previewAnnotationFilename)return;let previewApi=storybookPaths["@storybook/preview-api"],clientLogger=storybookPaths["@storybook/client-logger"],entryFilename=previewAnnotationFilename.startsWith(".")?`${previewAnnotationFilename.replace(/(\w)(\/|\\)/g,"$1-")}-generated-config-entry.js`:`${previewAnnotationFilename}-generated-config-entry.js`;virtualModuleMapping[entryFilename]=interpolate(entryTemplate,{previewAnnotationFilename,previewApi,clientLogger}),entries2.push(entryFilename)}),stories.length>0){let storyTemplate=await readTemplate(join(__dirname,"..","..","templates","virtualModuleStory.template.js")),storiesFilename=resolve(join(workingDir,"generated-stories-entry.cjs"));virtualModuleMapping[storiesFilename]=interpolate(storyTemplate,{rendererName}).replace("'{{stories}}'",stories.map(toRequireContextString).join(",")),entries2.push(storiesFilename)}}let shouldCheckTs=typescriptOptions.check&&!typescriptOptions.skipBabel,tsCheckOptions=typescriptOptions.checkOptions||{},cacheConfig=builderOptions.fsCache?{cache:{type:"filesystem"}}:{},lazyCompilationConfig=builderOptions.lazyCompilation&&!isProd?{lazyCompilation:{entries:!1}}:{};return{name:"preview",mode:isProd?"production":"development",bail:isProd,devtool:"cheap-module-source-map",entry:entries2,output:{path:resolve(process.cwd(),outputDir),filename:isProd?"[name].[contenthash:8].iframe.bundle.js":"[name].iframe.bundle.js",publicPath:""},stats:{preset:"none",logging:"error"},watchOptions:{ignored:/node_modules/},externals:globals,ignoreWarnings:[{message:/export '\S+' was not found in 'global'/}],plugins:[Object.keys(virtualModuleMapping).length>0?new VirtualModulePlugin(virtualModuleMapping):null,new HtmlWebpackPlugin({filename:"iframe.html",chunksSortMode:"none",alwaysWriteToDisk:!0,inject:!1,template,templateParameters:{version:packageJson.version,globals:{CONFIG_TYPE:configType,LOGLEVEL:logLevel,FRAMEWORK_OPTIONS:frameworkOptions,CHANNEL_OPTIONS:coreOptions.channelOptions,FEATURES:features,PREVIEW_URL:previewUrl,STORIES:stories.map(specifier=>({...specifier,importPathMatcher:specifier.importPathMatcher.source})),DOCS_OPTIONS:docsOptions,SERVER_CHANNEL_URL:serverChannelUrl},headHtmlSnippet,bodyHtmlSnippet},minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!0,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!0,useShortDoctype:!0}}),new DefinePlugin({...stringifyProcessEnvs(envs),NODE_ENV:JSON.stringify(process.env.NODE_ENV)}),new ProvidePlugin({process:__require.resolve("process/browser.js")}),isProd?null:new HotModuleReplacementPlugin,new CaseSensitivePathsPlugin,quiet?null:new ProgressPlugin({}),shouldCheckTs?new ForkTsCheckerWebpackPlugin(tsCheckOptions):null].filter(Boolean),module:{rules:[{test:/\.m?js$/,type:"javascript/auto"},{test:/\.m?js$/,resolve:{fullySpecified:!1}},createBabelLoader(babelOptions,typescriptOptions),{test:/\.md$/,type:"asset/source"}]},resolve:{extensions:[".mjs",".js",".jsx",".ts",".tsx",".json",".cjs"],modules:["node_modules"].concat(envs.NODE_PATH||[]),mainFields:["browser","module","main"].filter(Boolean),alias:storybookPaths,fallback:{path:__require.resolve("path-browserify"),assert:__require.resolve("browser-assert"),util:__require.resolve("util")},symlinks:!isPreservingSymlinks()},optimization:{splitChunks:{chunks:"all"},runtimeChunk:!0,sideEffects:!0,usedExports:isProd,moduleIds:"named",minimizer:isProd?[new TerserWebpackPlugin({parallel:!0,terserOptions:{sourceMap:!0,mangle:!1,keep_fnames:!0}})]:[]},performance:{hints:isProd?"warning":!1},...cacheConfig,experiments:{...lazyCompilationConfig}}};var webpack=async(_,options)=>iframe_webpack_config_default(options),entries=async(_,options)=>{let result=[];return options.configType==="DEVELOPMENT"&&(result=result.concat(`${__require.resolve("webpack-hot-middleware/client")}?reload=true&quiet=false&noInfo=${options.quiet}`)),result},babel=async(config,options)=>({...config,overrides:[...config?.overrides||[],{test:/\.(story|stories).*$/,plugins:[__require.resolve("babel-plugin-named-exports-order")]}]}),babelLoaderRef=()=>__require.resolve("babel-loader"),previewMainTemplate=()=>__require.resolve("@storybook/builder-webpack5/templates/preview.ejs");export{babel,babelLoaderRef,entries,previewMainTemplate,webpack};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@storybook/builder-webpack5",
3
- "version": "7.0.0-alpha.54",
3
+ "version": "7.0.0-alpha.56",
4
4
  "description": "Storybook framework-agnostic API",
5
5
  "keywords": [
6
6
  "storybook"
@@ -54,24 +54,24 @@
54
54
  },
55
55
  "dependencies": {
56
56
  "@babel/core": "^7.12.10",
57
- "@storybook/addons": "7.0.0-alpha.54",
58
- "@storybook/api": "7.0.0-alpha.54",
59
- "@storybook/channel-postmessage": "7.0.0-alpha.54",
60
- "@storybook/channel-websocket": "7.0.0-alpha.54",
61
- "@storybook/channels": "7.0.0-alpha.54",
62
- "@storybook/client-api": "7.0.0-alpha.54",
63
- "@storybook/client-logger": "7.0.0-alpha.54",
64
- "@storybook/components": "7.0.0-alpha.54",
65
- "@storybook/core-common": "7.0.0-alpha.54",
66
- "@storybook/core-events": "7.0.0-alpha.54",
67
- "@storybook/core-webpack": "7.0.0-alpha.54",
68
- "@storybook/manager-api": "7.0.0-alpha.54",
69
- "@storybook/node-logger": "7.0.0-alpha.54",
70
- "@storybook/preview": "7.0.0-alpha.54",
71
- "@storybook/preview-api": "7.0.0-alpha.54",
72
- "@storybook/router": "7.0.0-alpha.54",
73
- "@storybook/store": "7.0.0-alpha.54",
74
- "@storybook/theming": "7.0.0-alpha.54",
57
+ "@storybook/addons": "7.0.0-alpha.56",
58
+ "@storybook/api": "7.0.0-alpha.56",
59
+ "@storybook/channel-postmessage": "7.0.0-alpha.56",
60
+ "@storybook/channel-websocket": "7.0.0-alpha.56",
61
+ "@storybook/channels": "7.0.0-alpha.56",
62
+ "@storybook/client-api": "7.0.0-alpha.56",
63
+ "@storybook/client-logger": "7.0.0-alpha.56",
64
+ "@storybook/components": "7.0.0-alpha.56",
65
+ "@storybook/core-common": "7.0.0-alpha.56",
66
+ "@storybook/core-events": "7.0.0-alpha.56",
67
+ "@storybook/core-webpack": "7.0.0-alpha.56",
68
+ "@storybook/manager-api": "7.0.0-alpha.56",
69
+ "@storybook/node-logger": "7.0.0-alpha.56",
70
+ "@storybook/preview": "7.0.0-alpha.56",
71
+ "@storybook/preview-api": "7.0.0-alpha.56",
72
+ "@storybook/router": "7.0.0-alpha.56",
73
+ "@storybook/store": "7.0.0-alpha.56",
74
+ "@storybook/theming": "7.0.0-alpha.56",
75
75
  "@types/node": "^16.0.0",
76
76
  "@types/semver": "^7.3.4",
77
77
  "babel-loader": "^8.3.0",
@@ -126,5 +126,5 @@
126
126
  ],
127
127
  "platform": "node"
128
128
  },
129
- "gitHead": "91177d4e27daec556a24ae6223c3cbe17a998d9b"
129
+ "gitHead": "c8e9a862bb83c4a0d6b5975e795b4ca7f7ff7bc2"
130
130
  }