import { getThisCodebaseRootDirPath } from "./tools/getThisCodebaseRootDirPath"; import cliSelect from "cli-select"; import { LOGIN_THEME_PAGE_IDS, ACCOUNT_THEME_PAGE_IDS, type LoginThemePageId, type AccountThemePageId, THEME_TYPES, type ThemeType } from "./shared/constants"; import { capitalize } from "tsafe/capitalize"; import * as fs from "fs"; import { join as pathJoin, relative as pathRelative, dirname as pathDirname } from "path"; import { kebabCaseToCamelCase } from "./tools/kebabCaseToSnakeCase"; import { assert, Equals } from "tsafe/assert"; import type { CliCommandOptions } from "./main"; import { getBuildContext } from "./shared/buildContext"; import chalk from "chalk"; export async function command(params: { cliCommandOptions: CliCommandOptions }) { const { cliCommandOptions } = params; const buildContext = getBuildContext({ cliCommandOptions }); console.log(chalk.cyan("Theme type:")); const { value: themeType } = await cliSelect({ values: [...THEME_TYPES] }).catch(() => { process.exit(-1); }); console.log(`→ ${themeType}`); console.log(chalk.cyan("Select the page you want to create a Storybook for:")); const { value: pageId } = await cliSelect({ values: (() => { switch (themeType) { case "login": return [...LOGIN_THEME_PAGE_IDS]; case "account": return [...ACCOUNT_THEME_PAGE_IDS]; } assert>(false); })() }).catch(() => { process.exit(-1); }); console.log(`→ ${pageId}`); const componentBasename = capitalize(kebabCaseToCamelCase(pageId)).replace( /ftl$/, "stories.tsx" ); const targetFilePath = pathJoin( buildContext.themeSrcDirPath, themeType, "pages", componentBasename ); if (fs.existsSync(targetFilePath)) { console.log(`${pathRelative(process.cwd(), targetFilePath)} already exists`); process.exit(-1); } const componentCode = fs .readFileSync( pathJoin( getThisCodebaseRootDirPath(), "stories", themeType, "pages", componentBasename ) ) .toString("utf8") .replace('import React from "react";\n', "") .replace(/from "[./]+dist\//, 'from "keycloakify/'); { const targetDirPath = pathDirname(targetFilePath); if (!fs.existsSync(targetDirPath)) { fs.mkdirSync(targetDirPath, { recursive: true }); } } fs.writeFileSync(targetFilePath, Buffer.from(componentCode, "utf8")); console.log( [ `${chalk.green("✓")} ${chalk.bold( pathJoin(".", pathRelative(process.cwd(), targetFilePath)) )} copy pasted from the Keycloakify source code into your project`, `You can start storybook with ${chalk.bold("npm run storybook")}` ].join("\n") ); }