From f628b2ec016d1340d5b765e08415e5da694c4a42 Mon Sep 17 00:00:00 2001 From: Dan McGrath Date: Mon, 2 Dec 2024 13:16:47 -0500 Subject: [PATCH] fix: storybook dev command Fixes the following error when running pnpm storybook:dev locally: ``` SB_CORE-SERVER_0002 (CriticalPresetLoadError): Storybook failed to load the following preset: @storybook/react-webpack5/preset. ``` Reference: https://storybook.js.org/docs/faq#how-do-i-fix-module-resolution-in-special-environments --- .storybook/main.ts | 115 +++++++++++++++++++++++---------------------- 1 file changed, 59 insertions(+), 56 deletions(-) diff --git a/.storybook/main.ts b/.storybook/main.ts index dc3a34f9e..aa25a9592 100644 --- a/.storybook/main.ts +++ b/.storybook/main.ts @@ -1,56 +1,59 @@ -import type { StorybookConfig } from "@storybook/react-webpack5"; - -/* globals __dirname:false */ -const path = require("path"); -const ROOT = path.resolve(__dirname, ".."); -const STORIES = path.resolve(ROOT, "stories"); - -const config: StorybookConfig = { - addons: [ - "@storybook/addon-essentials", - { - name: "@storybook/addon-storysource", - options: { - rule: { - test: [/\.stories\.(jsx?|tsx?)$/], - include: [STORIES], - }, - loaderOptions: { - prettierConfig: { printWidth: 80, singleQuote: false }, - }, - }, - }, - "@storybook/addon-webpack5-compiler-swc", - "@chromatic-com/storybook", - ], - - framework: { - name: "@storybook/react-webpack5", - options: { - builder: {}, - }, - }, - - stories: ["../stories/**/*.stories.tsx"], - - typescript: { - check: false, - checkOptions: { - typescript: { - configFile: path.resolve(ROOT, "tsconfig.storybook.json"), - }, - }, - }, - - webpackFinal: async (config) => { - if (config.resolve) { - config.resolve.alias = { - ...config.resolve.alias, - "@": path.resolve(__dirname, "../packages"), - }; - } - return config; - }, -}; - -export default config; +import type { StorybookConfig } from "@storybook/react-webpack5"; + +/* globals __dirname:false */ +const path = require("path"); +const ROOT = path.resolve(__dirname, ".."); +const STORIES = path.resolve(ROOT, "stories"); + +const getAbsolutePath = (packageName: string): any => + path.dirname(require.resolve(path.join(packageName, 'package.json'))); + +const config: StorybookConfig = { + addons: [ + getAbsolutePath("@storybook/addon-essentials"), + { + name: "@storybook/addon-storysource", + options: { + rule: { + test: [/\.stories\.(jsx?|tsx?)$/], + include: [STORIES], + }, + loaderOptions: { + prettierConfig: { printWidth: 80, singleQuote: false }, + }, + }, + }, + getAbsolutePath("@storybook/addon-webpack5-compiler-swc"), + getAbsolutePath("@chromatic-com/storybook"), + ], + + framework: { + name: getAbsolutePath("@storybook/react-webpack5"), + options: { + builder: {}, + }, + }, + + stories: ["../stories/**/*.stories.tsx"], + + typescript: { + check: false, + checkOptions: { + typescript: { + configFile: path.resolve(ROOT, "tsconfig.storybook.json"), + }, + }, + }, + + webpackFinal: async (config) => { + if (config.resolve) { + config.resolve.alias = { + ...config.resolve.alias, + "@": path.resolve(__dirname, "../packages"), + }; + } + return config; + }, +}; + +export default config;