@react-native-reusables/cli 0.3.4 → 0.3.5

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.
package/dist/index.js CHANGED
@@ -15,7 +15,7 @@ cssInterop(icon, {
15
15
  }`)}catch(c){m(c)}}if(b(l.join(s,`${i}.tsx`))){let c=l.join(s,`${i}.tsx`);if(!r){a.info(`File already exists: ${x.bgCyan(`${i}.tsx`)} was skipped. To overwrite, run with the ${x.green("--overwrite")} flag.`);continue}let{overwrite:d}=await L({type:"confirm",name:"overwrite",message:`File already exists: ${x.yellow(c)}. Would you like to overwrite?`,initial:!1});if(!d){a.info(`Skipped ${i}.tsx`);continue}}n.start(`Adding the ${i} icon...`);try{await w.writeFile(l.join(s,`${i}.tsx`),`import { ${i} } from 'lucide-react-native';
16
16
  import { iconWithClassName } from './iconWithClassName';
17
17
  iconWithClassName(${i});
18
- export { ${i} };`)}catch(c){m(c)}}}function ve(e,t,o){return e.replace("./typography",`${t}/ui/typography`).replace("./text",`${t}/ui/text`).replaceAll("../../components",t).replaceAll("../../lib",o)}import{existsSync as H,promises as k}from"fs";import T from"path";async function M(e,t,o={ignore:[],renameTemplateFiles:!1}){if(!H(e))throw new Error(`Source folder does not exist: ${e}`);H(t)||await k.mkdir(t,{recursive:!0});let n=await k.readdir(e,{withFileTypes:!0});for(let r of n){let i=T.join(e,r.name),s=T.join(t,r.name);o.ignore.includes(r.name)||(r.isDirectory()?await M(i,s,o):r.isFile()&&(o.renameTemplateFiles&&r.name==="gitignore-template"?await k.copyFile(i,T.join(t,".gitignore")):o.renameTemplateFiles&&r.name==="npmrc-template"?await k.copyFile(i,T.join(t,".npmrc")):await k.copyFile(i,s)))}}import C from"chalk";import{execSync as Q}from"child_process";import{Command as be}from"commander";import{execa as U}from"execa";import ke from"fast-glob";import{existsSync as v,promises as u}from"fs";import Y from"ora";import p from"path";import P from"prompts";import{fileURLToPath as Ce}from"url";import{z as W}from"zod";var Pe=Ce(import.meta.url),Z=p.dirname(Pe),je=["nativewind","expo-navigation-bar","tailwindcss-animate","class-variance-authority","clsx","tailwind-merge","react-native-svg","lucide-react-native","@rn-primitives/portal"],_e=["tailwind.config.js","nativewind-env.d.ts","global.css","babel.config.js","metro.config.js","lib/utils.ts","lib/useColorScheme.tsx","lib/constants.ts","lib/android-navigation-bar.ts","lib/icons/iconWithClassName.ts"],Fe=W.object({cwd:W.string(),overwrite:W.boolean()}),ee=new be().name("init").description("Initialize the required configuration for your React Native project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-o, --overwrite","overwrite existing files",!1).action(async e=>{try{let t=Fe.parse(e),o=p.resolve(t.cwd);await Se(o),await Ne(o),await Ee(o,t.overwrite)}catch(t){m(t)}});async function Se(e){if(v(e)&&v(p.join(e,"package.json"))){let{option:s}=await P({type:"select",name:"option",message:'Package.json found. How would you like to proceed? (Selecting "Cancel" will exit the process)',choices:[{title:"Automatically configure your existing project",value:"existing-project"},{title:"Init new project",value:"new-project"},{title:"Cancel",value:"cancel"}],initial:!1});if(s==="cancel"&&(a.info("Installation cancelled."),process.exit(0)),s==="existing-project")return}let{projectName:t}=await P({type:"text",name:"projectName",message:"What is the name of your project?",initial:"starter-base"}),{packageManager:o}=await P({type:"select",name:"packageManager",message:"Which package manager would you like to use?",choices:[{title:"npm",value:"npm"},{title:"yarn",value:"yarn"},{title:"pnpm",value:"pnpm"},{title:"bun",value:"bun"}]}),n=Y(`Initializing ${t}...`).start(),r=p.join(e,t);v(r)||await u.mkdir(r,{recursive:!0});let i=[];o!=="pnpm"&&i.push("npmrc-template"),await M(p.join(Z,"../__generated/starter-base"),r,{ignore:i,renameTemplateFiles:!0}),await Promise.all([X(p.join(r,"app.json"),"starter-base",t),X(p.join(r,"package.json"),"@rnr/starter-base",t)]),n.start("Installing dependencies..."),await U(o,["install"],{cwd:r}),n.text="Verifying and updating any invalid package versions if needed...",await U("npx",["expo","install","--fix"],{cwd:r}),n.succeed("New project initialized successfully!"),console.log(`
18
+ export { ${i} };`)}catch(c){m(c)}}}function ve(e,t,o){return e.replace("./typography",`${t}/ui/typography`).replace("./text",`${t}/ui/text`).replaceAll("../../components",t).replaceAll("../../lib",o)}import{existsSync as H,promises as k}from"fs";import T from"path";async function M(e,t,o={ignore:[],renameTemplateFiles:!1}){if(!H(e))throw new Error(`Source folder does not exist: ${e}`);H(t)||await k.mkdir(t,{recursive:!0});let n=await k.readdir(e,{withFileTypes:!0});for(let r of n){let i=T.join(e,r.name),s=T.join(t,r.name);o.ignore.includes(r.name)||(r.isDirectory()?await M(i,s,o):r.isFile()&&(o.renameTemplateFiles&&r.name==="gitignore-template"?await k.copyFile(i,T.join(t,".gitignore")):o.renameTemplateFiles&&r.name==="npmrc-template"?await k.copyFile(i,T.join(t,".npmrc")):await k.copyFile(i,s)))}}import C from"chalk";import{execSync as Q}from"child_process";import{Command as be}from"commander";import{execa as U}from"execa";import ke from"fast-glob";import{existsSync as v,promises as u}from"fs";import Y from"ora";import p from"path";import P from"prompts";import{fileURLToPath as Ce}from"url";import{z as W}from"zod";var Pe=Ce(import.meta.url),Z=p.dirname(Pe),je=["nativewind","expo-navigation-bar","tailwindcss","tailwindcss-animate","class-variance-authority","clsx","tailwind-merge","react-native-svg","react-native-reanimated","react-native-safe-area-context","lucide-react-native","@rn-primitives/portal"],_e=["tailwind.config.js","nativewind-env.d.ts","global.css","babel.config.js","metro.config.js","lib/utils.ts","lib/useColorScheme.tsx","lib/constants.ts","lib/android-navigation-bar.ts","lib/icons/iconWithClassName.ts"],Fe=W.object({cwd:W.string(),overwrite:W.boolean()}),ee=new be().name("init").description("Initialize the required configuration for your React Native project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-o, --overwrite","overwrite existing files",!1).action(async e=>{try{let t=Fe.parse(e),o=p.resolve(t.cwd);await Se(o),await Ne(o),await Ee(o,t.overwrite)}catch(t){m(t)}});async function Se(e){if(v(e)&&v(p.join(e,"package.json"))){let{option:s}=await P({type:"select",name:"option",message:'Package.json found. How would you like to proceed? (Selecting "Cancel" will exit the process)',choices:[{title:"Automatically configure your existing project",value:"existing-project"},{title:"Init new project",value:"new-project"},{title:"Cancel",value:"cancel"}],initial:!1});if(s==="cancel"&&(a.info("Installation cancelled."),process.exit(0)),s==="existing-project")return}let{projectName:t}=await P({type:"text",name:"projectName",message:"What is the name of your project?",initial:"starter-base"}),{packageManager:o}=await P({type:"select",name:"packageManager",message:"Which package manager would you like to use?",choices:[{title:"npm",value:"npm"},{title:"yarn",value:"yarn"},{title:"pnpm",value:"pnpm"},{title:"bun",value:"bun"}]}),n=Y(`Initializing ${t}...`).start(),r=p.join(e,t);v(r)||await u.mkdir(r,{recursive:!0});let i=[];o!=="pnpm"&&i.push("npmrc-template"),await M(p.join(Z,"../__generated/starter-base"),r,{ignore:i,renameTemplateFiles:!0}),await Promise.all([X(p.join(r,"app.json"),"starter-base",t),X(p.join(r,"package.json"),"@rnr/starter-base",t)]),n.start("Installing dependencies..."),await U(o,["install"],{cwd:r}),n.text="Verifying and updating any invalid package versions if needed...",await U("npx",["expo","install","--fix"],{cwd:r}),n.succeed("New project initialized successfully!"),console.log(`
19
19
  To get started, run the following commands:
20
20
  `),console.log(C.cyan(`cd ${t}`)),console.log(C.cyan(`${o} ${o==="npm"||o==="bun"?"run ":""}dev`)),process.exit(0)}async function X(e,t,o){try{v(e)||(a.error(`The path ${e} does not exist.`),process.exit(1));let r=(await u.readFile(e,"utf8")).replaceAll(t,o);await u.writeFile(e,r)}catch(n){m(n)}}async function Ne(e){if(await $e(e)){let{proceed:t}=await P({type:"confirm",name:"proceed",message:"The Git repository is dirty (uncommitted changes). It is recommended to commit your changes before proceeding. Do you want to continue?",initial:!1});t||(a.info("Installation cancelled."),process.exit(0))}}async function $e(e){try{return Q("git rev-parse --is-inside-work-tree",{cwd:e}),!!Q("git status --porcelain",{cwd:e}).toString()}catch{return!1}}async function Ee(e,t){let o=Y("Initializing project...").start();try{let n=await S(e);n||(o.stop(),n=await $(e),o.start());let r=p.join(Z,"../__generated/starter-base");await Te(e,o),await Ie(e,n,o),o.text="Adding config and utility files...";for(let i of _e)await Oe(i,r,e,o,t);await De(e,o),o.succeed("Initialization completed successfully!")}catch(n){o.fail("Initialization failed"),m(n),process.exit(1)}}async function Te(e,t){try{t.text="Installing dependencies...",await U("npx",["expo","install",...je],{cwd:e,stdio:"inherit"}),t.text="Dependencies installed successfully"}catch(o){t.fail("Failed to install dependencies"),m(o),process.exit(1)}}var K=["",".","/"];async function Ie(e,t,o){try{let n=p.join(e,"tsconfig.json"),r=v(n)?JSON.parse(await u.readFile(n,"utf8")):{},i=t.aliases.components.split("/")[0],s=t.aliases.lib.split("/")[0];if(K.includes(i)||K.includes(s))return;let c=r.compilerOptions?.paths??{};if(c[`${i}/*`]?.[0]==="*"&&c[`${s}/*`]?.[0]==="*"){o.succeed("Path aliases already configured");return}o.text="Updating path aliases...",r.compilerOptions={...r.compilerOptions,baseUrl:".",paths:{[`${i}/*`]:["*"],[`${s}/*`]:["*"],...r.compilerOptions?.paths}},await u.writeFile(n,JSON.stringify(r,null,2))}catch(n){o.fail("Failed to update tsconfig.json"),m(n)}}async function Oe(e,t,o,n,r){let i=p.join(o,e);if(n.stop(),v(i)){if(!r){a.info(`File already exists: ${C.bgCyan(e)} was skipped. To overwrite, run with the ${C.green("--overwrite")} flag.`);return}let{overwrite:s}=await P({type:"confirm",name:"overwrite",message:`File already exists: ${C.yellow(e)}. Would you like to overwrite?`,initial:!1});if(!s){a.info("Skipped");return}}n.start(`Installing ${e}...`),await u.mkdir(p.dirname(i),{recursive:!0}),await u.copyFile(p.join(t,e),i)}async function De(e,t){try{let o=await ke(["app/_layout.{ts,tsx,js,jsx}","(app)/_layout.{ts,tsx,js,jsx}"],{cwd:e,ignore:["node_modules/**"]});if(!o.length){t.warn("Could not find the root _layout file");return}let n=p.join(e,o[0]),r=await u.readFile(n,"utf8");r.includes('import "../global.css"')||(t.text="Updating layout file...",await u.writeFile(n,`import "../global.css";
21
21
  ${r}`),t.succeed(`Updated ${o[0]} with global CSS import`))}catch(o){t.fail("Failed to update layout file"),m(o)}}import{Command as Ae}from"commander";process.on("SIGINT",()=>process.exit(0));process.on("SIGTERM",()=>process.exit(0));async function Re(){let e=new Ae().name("@react-native-reusables/cli").description("add components and dependencies to your project");e.addCommand(q),e.addCommand(ee),e.parse()}Re();
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/utils/resolve-import.ts","../src/utils/get-config.ts","../src/utils/get-package-manager.ts","../src/utils/logger.ts","../src/utils/handle-error.ts","../src/utils/prompt-for-config.ts","../src/commands/add.ts","../src/items/components.ts","../src/items/index.ts","../src/utils/copy-folder.ts","../src/commands/init.ts","../src/index.ts"],"sourcesContent":["import { createMatchPath, type ConfigLoaderSuccessResult } from \"tsconfig-paths\"\n\nexport async function resolveImport(\n importPath: string,\n config: Pick<ConfigLoaderSuccessResult, \"absoluteBaseUrl\" | \"paths\">\n) {\n return createMatchPath(config.absoluteBaseUrl, config.paths)(\n importPath,\n undefined,\n () => true,\n [\".ts\", \".tsx\"]\n )\n}\n","import { resolveImport } from '@/src/utils/resolve-import';\nimport { cosmiconfig } from 'cosmiconfig';\nimport { loadConfig } from 'tsconfig-paths';\nimport { z } from 'zod';\n\nexport const DEFAULT_COMPONENTS = '~/components';\nexport const DEFAULT_LIB = '~/lib';\n\nconst explorer = cosmiconfig('components', {\n searchPlaces: ['components.json'],\n});\n\nexport const rawConfigSchema = z.object({\n aliases: z.object({\n components: z.string(),\n lib: z.string(),\n }),\n});\n\nexport type RawConfig = z.infer<typeof rawConfigSchema>;\n\nexport const configSchema = rawConfigSchema.extend({\n resolvedPaths: z.object({\n lib: z.string(),\n components: z.string(),\n }),\n});\n\nexport type Config = z.infer<typeof configSchema>;\n\nexport async function getConfig(cwd: string) {\n const config = await getRawConfig(cwd);\n\n if (!config) {\n return null;\n }\n\n return await resolveConfigPaths(cwd, config);\n}\n\nexport async function resolveConfigPaths(cwd: string, config: RawConfig) {\n // Read tsconfig.json.\n const tsConfig = await loadConfig(cwd);\n\n if (tsConfig.resultType === 'failed') {\n throw new Error(`Failed to load tsconfig.json. ${tsConfig.message ?? ''}`.trim());\n }\n\n return configSchema.parse({\n ...config,\n resolvedPaths: {\n lib: await resolveImport(config.aliases['lib'], tsConfig),\n components: await resolveImport(config.aliases['components'], tsConfig),\n },\n });\n}\n\nexport async function getRawConfig(cwd: string): Promise<RawConfig | null> {\n try {\n const configResult = await explorer.search(cwd);\n\n if (!configResult) {\n return null;\n }\n\n return rawConfigSchema.parse(configResult.config);\n } catch (error) {\n throw new Error(`Invalid configuration found in ${cwd}/components.json.`);\n }\n}\n","import { detect } from '@antfu/ni';\n\nexport async function getPackageManager(\n targetDir: string\n): Promise<'yarn' | 'pnpm' | 'bun' | 'npm'> {\n const packageManager = await detect({ programmatic: true, cwd: targetDir });\n\n if (packageManager === 'yarn@berry') return 'yarn';\n if (packageManager === 'pnpm@6') return 'pnpm';\n if (packageManager === 'bun') return 'bun';\n\n return packageManager ?? 'npm';\n}\n","import chalk from \"chalk\"\n\nexport const logger = {\n error(...args: unknown[]) {\n console.log(chalk.red(...args))\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(...args))\n },\n info(...args: unknown[]) {\n console.log(chalk.cyan(...args))\n },\n success(...args: unknown[]) {\n console.log(chalk.green(...args))\n },\n break() {\n console.log(\"\")\n },\n}\n","import { logger } from \"@/src/utils/logger\"\n\nexport function handleError(error: unknown) {\n if (typeof error === \"string\") {\n logger.error(error)\n process.exit(1)\n }\n\n if (error instanceof Error) {\n logger.error(error.message)\n process.exit(1)\n }\n\n logger.error(\"Something went wrong. Please try again.\")\n process.exit(1)\n}\n","import {\n DEFAULT_COMPONENTS,\n DEFAULT_LIB,\n rawConfigSchema,\n resolveConfigPaths,\n} from '@/src/utils/get-config';\nimport { logger } from '@/src/utils/logger';\nimport chalk from 'chalk';\nimport { promises as fs } from 'fs';\nimport ora from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\n\nexport async function promptForConfig(cwd: string) {\n const highlight = (text: string) => chalk.cyan(text);\n\n const options = await prompts([\n {\n type: 'text',\n name: 'components',\n message: `Configure the import alias for ${highlight('components')}:`,\n initial: DEFAULT_COMPONENTS,\n },\n {\n type: 'text',\n name: 'lib',\n message: `Configure the import alias for ${highlight('lib')}:`,\n initial: DEFAULT_LIB,\n },\n ]);\n\n const config = rawConfigSchema.parse({\n aliases: {\n lib: options.lib || DEFAULT_COMPONENTS,\n components: options.components || DEFAULT_LIB,\n },\n });\n\n const { proceed } = await prompts({\n type: 'confirm',\n name: 'proceed',\n message: `Write configuration to ${highlight('components.json')}. Proceed?`,\n initial: true,\n });\n\n if (proceed) {\n logger.info('');\n const spinner = ora(`Writing components.json...`).start();\n const targetPath = path.resolve(cwd, 'components.json');\n await fs.writeFile(targetPath, JSON.stringify(config, null, 2), 'utf8');\n spinner.succeed();\n }\n\n return await resolveConfigPaths(cwd, config);\n}\n","import { Config, getConfig } from '@/src/utils/get-config';\nimport { getPackageManager } from '@/src/utils/get-package-manager';\nimport { handleError } from '@/src/utils/handle-error';\nimport { logger } from '@/src/utils/logger';\nimport { promptForConfig } from '@/src/utils/prompt-for-config';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport { existsSync, promises as fs } from 'fs';\nimport ora, { Ora } from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\nimport { fileURLToPath } from 'url';\nimport { z } from 'zod';\nimport { Component, INVALID_COMPONENT_ERROR, getAllComponentsToWrite } from '../items';\nimport { COMPONENTS } from '../items/components';\n\nconst filePath = fileURLToPath(import.meta.url);\nconst fileDir = path.dirname(filePath);\n\nconst addOptionsSchema = z.object({\n components: z.array(z.string()).optional(),\n overwrite: z.boolean(),\n cwd: z.string(),\n path: z.string().optional(),\n});\n\nexport const add = new Command()\n .name('add')\n .description('add components to your project')\n .argument('[components...]', 'the components to add')\n .option('-o, --overwrite', 'overwrite existing files.', false)\n .option(\n '-c, --cwd <cwd>',\n 'the working directory. defaults to the current directory.',\n process.cwd()\n )\n .action(async (components, opts) => {\n try {\n const options = addOptionsSchema.parse({\n components,\n ...opts,\n });\n\n const cwd = path.resolve(options.cwd);\n\n if (!existsSync(cwd)) {\n logger.error(`The path ${cwd} does not exist. Please try again.`);\n process.exit(1);\n }\n\n let config = await getConfig(cwd);\n\n if (!config) {\n config = await promptForConfig(cwd);\n }\n\n let selectedComponents: Array<string> = options.components ?? [];\n if (!selectedComponents?.length) {\n const { components } = await prompts({\n type: 'multiselect',\n name: 'components',\n message: 'Which components would you like to add?',\n hint: 'Space to select. A to toggle all. Enter to submit.',\n instructions: false,\n choices: COMPONENTS.map((entry) => ({\n title: entry.name,\n value: entry.name,\n selected: false,\n })),\n });\n selectedComponents = components;\n }\n\n if (!selectedComponents?.length) {\n logger.warn('No components selected. Exiting.');\n process.exit(0);\n }\n\n const spinner = ora(`Installing components...`).start();\n\n let componentsToWrite: Array<Component> = [];\n try {\n componentsToWrite = getAllComponentsToWrite(selectedComponents);\n } catch (err) {\n if (err instanceof Error && err.message === INVALID_COMPONENT_ERROR) {\n logger.error(\n `Invalid component(s): ${selectedComponents\n .filter((component) => !COMPONENTS.find((entry) => entry.name === component))\n .join(', ')}`\n );\n process.exit(1);\n }\n logger.error(err);\n }\n\n const npmPackages: Array<string> = [];\n\n for (const comp of componentsToWrite) {\n spinner.text = `Installing ${comp.name}...`;\n\n await writeFiles(comp, comp.paths, config, spinner, options.overwrite);\n\n npmPackages.push(...comp.npmPackages);\n }\n\n const packageManager = await getPackageManager(cwd);\n\n const uniqueNpmPackages = Array.from(new Set(npmPackages));\n\n if (uniqueNpmPackages.length) {\n spinner.text = `Installing ${uniqueNpmPackages.join(', ')}...`;\n await execa(\n packageManager,\n [packageManager === 'npm' ? 'install' : 'add', ...uniqueNpmPackages],\n {\n cwd,\n }\n );\n }\n spinner.succeed(`Done.`);\n } catch (error) {\n handleError(error);\n }\n });\n\nasync function writeFiles(\n comp: Component,\n paths: Array<{ from: string; distFrom?: string; to: { folder: string; file: string } }>,\n config: Config,\n spinner: Ora,\n overwriteFlag: boolean\n) {\n for (const compPath of paths) {\n const targetDir = path.join(config.resolvedPaths.components, compPath.to.folder);\n if (!existsSync(targetDir)) {\n await fs.mkdir(targetDir, { recursive: true });\n }\n\n spinner.stop();\n\n if (existsSync(path.join(targetDir, compPath.to.file))) {\n const filePath = [compPath.to.folder, compPath.to.file].join('/');\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n filePath\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n continue;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(filePath)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped`);\n continue;\n }\n }\n\n spinner.start(`Installing ${comp.name}...`);\n const readFromPath = compPath.distFrom\n ? path.join(fileDir, '../__generated/components', compPath.distFrom)\n : path.join(fileDir, '../__generated/components', compPath.to.folder, compPath.to.file);\n try {\n const content = await fs.readFile(path.resolve(readFromPath), 'utf8');\n await fs.writeFile(\n path.join(targetDir, compPath.to.file),\n fixImports(content, config.aliases.components, config.aliases.lib)\n );\n } catch (error) {\n handleError(error);\n }\n }\n\n for (const icon of comp.icons ?? []) {\n const targetDir = path.resolve(config.resolvedPaths.lib, 'icons');\n if (!existsSync(targetDir)) {\n await fs.mkdir(targetDir, { recursive: true });\n try {\n await fs.writeFile(\n path.join(targetDir, `iconWithClassName.ts`),\n `import type { LucideIcon } from 'lucide-react-native';\\nimport { cssInterop } from 'nativewind';\\n\\nexport function iconWithClassName(icon: LucideIcon) {\\ncssInterop(icon, {\\n className: {\\n target: 'style',\\n nativeStyleToProp: {\\n color: true,\\n opacity: true,\\n },\\n },\\n});\\n}`\n );\n } catch (error) {\n handleError(error);\n }\n }\n\n if (existsSync(path.join(targetDir, `${icon}.tsx`))) {\n const filePath = path.join(targetDir, `${icon}.tsx`);\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n `${icon}.tsx`\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n continue;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(filePath)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped ${icon}.tsx`);\n continue;\n }\n }\n\n spinner.start(`Adding the ${icon} icon...`);\n\n try {\n await fs.writeFile(\n path.join(targetDir, `${icon}.tsx`),\n `import { ${icon} } from 'lucide-react-native';\\nimport { iconWithClassName } from './iconWithClassName';\\niconWithClassName(${icon});\\nexport { ${icon} };`\n );\n } catch (error) {\n handleError(error);\n }\n }\n}\n\nfunction fixImports(rawfile: string, componentsAlias: string, libAlias: string) {\n return rawfile\n .replace('./typography', `${componentsAlias}/ui/typography`)\n .replace('./text', `${componentsAlias}/ui/text`)\n .replaceAll('../../components', componentsAlias)\n .replaceAll('../../lib', libAlias);\n}\n","export const COMPONENTS = [\n {\n name: 'accordion',\n dependencies: ['text'],\n icons: ['ChevronDown'],\n npmPackages: ['@rn-primitives/accordion'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/accordion.tsx',\n to: {\n folder: 'ui',\n file: 'accordion.tsx',\n },\n },\n ],\n },\n {\n name: 'alert',\n dependencies: ['text'],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/alert.tsx',\n to: {\n folder: 'ui',\n file: 'alert.tsx',\n },\n },\n ],\n },\n {\n name: 'alert-dialog',\n dependencies: ['button', 'text'],\n icons: [],\n npmPackages: ['@rn-primitives/alert-dialog'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/alert-dialog.tsx',\n to: {\n folder: 'ui',\n file: 'alert-dialog.tsx',\n },\n },\n ],\n },\n {\n name: 'aspect-ratio',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/aspect-ratio'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/aspect-ratio.tsx',\n to: {\n folder: 'ui',\n file: 'aspect-ratio.tsx',\n },\n },\n ],\n },\n {\n name: 'avatar',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/avatar'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/avatar.tsx',\n to: {\n folder: 'ui',\n file: 'avatar.tsx',\n },\n },\n ],\n },\n {\n name: 'badge',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/badge.tsx',\n to: {\n folder: 'ui',\n file: 'badge.tsx',\n },\n },\n ],\n },\n {\n name: 'button',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/button.tsx',\n to: {\n folder: 'ui',\n file: 'button.tsx',\n },\n },\n ],\n },\n {\n name: 'card',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/card.tsx',\n to: {\n folder: 'ui',\n file: 'card.tsx',\n },\n },\n ],\n },\n {\n name: 'checkbox',\n dependencies: [],\n icons: ['Check'],\n npmPackages: ['@rn-primitives/checkbox'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/checkbox.tsx',\n to: {\n folder: 'ui',\n file: 'checkbox.tsx',\n },\n },\n ],\n },\n {\n name: 'collapsible',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/collapsible'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/collapsible.tsx',\n to: {\n folder: 'ui',\n file: 'collapsible.tsx',\n },\n },\n ],\n },\n {\n name: 'context-menu',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/context-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/context-menu.tsx',\n to: {\n folder: 'ui',\n file: 'context-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'dialog',\n dependencies: [],\n icons: ['X'],\n npmPackages: ['@rn-primitives/dialog'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/dialog.tsx',\n to: {\n folder: 'ui',\n file: 'dialog.tsx',\n },\n },\n ],\n },\n {\n name: 'dropdown-menu',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/dropdown-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/dropdown-menu.tsx',\n to: {\n folder: 'ui',\n file: 'dropdown-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'hover-card',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/hover-card'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/hover-card.tsx',\n to: {\n folder: 'ui',\n file: 'hover-card.tsx',\n },\n },\n ],\n },\n {\n name: 'input',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/input.tsx',\n to: {\n folder: 'ui',\n file: 'input.tsx',\n },\n },\n ],\n },\n {\n name: 'label',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/label'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/label.tsx',\n to: {\n folder: 'ui',\n file: 'label.tsx',\n },\n },\n ],\n },\n {\n name: 'menubar',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/menubar'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/menubar.tsx',\n to: {\n folder: 'ui',\n file: 'menubar.tsx',\n },\n },\n ],\n },\n {\n name: 'navigation-menu',\n dependencies: [],\n icons: ['ChevronDown'],\n npmPackages: ['@rn-primitives/navigation-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/navigation-menu.tsx',\n to: {\n folder: 'ui',\n file: 'navigation-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'popover',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/popover'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/popover.tsx',\n to: {\n folder: 'ui',\n file: 'popover.tsx',\n },\n },\n ],\n },\n {\n name: 'progress',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/progress'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/progress.tsx',\n to: {\n folder: 'ui',\n file: 'progress.tsx',\n },\n },\n ],\n },\n {\n name: 'radio-group',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/radio-group'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/radio-group.tsx',\n to: {\n folder: 'ui',\n file: 'radio-group.tsx',\n },\n },\n ],\n },\n {\n name: 'select',\n dependencies: [],\n icons: ['Check', 'ChevronDown', 'ChevronUp'],\n npmPackages: ['@rn-primitives/select'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/select.tsx',\n to: {\n folder: 'ui',\n file: 'select.tsx',\n },\n },\n ],\n },\n {\n name: 'separator',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/separator'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/separator.tsx',\n to: {\n folder: 'ui',\n file: 'separator.tsx',\n },\n },\n ],\n },\n {\n name: 'skeleton',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/skeleton.tsx',\n to: {\n folder: 'ui',\n file: 'skeleton.tsx',\n },\n },\n ],\n },\n {\n name: 'switch',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/switch'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/switch.tsx',\n to: {\n folder: 'ui',\n file: 'switch.tsx',\n },\n },\n ],\n },\n {\n name: 'table',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/table'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/table.tsx',\n to: {\n folder: 'ui',\n file: 'table.tsx',\n },\n },\n ],\n },\n {\n name: 'tabs',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/tabs'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/tabs.tsx',\n to: {\n folder: 'ui',\n file: 'tabs.tsx',\n },\n },\n ],\n },\n {\n name: 'text',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/text.tsx',\n to: { folder: 'ui', file: 'text.tsx' },\n },\n ],\n },\n {\n name: 'textarea',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/textarea.tsx',\n to: { folder: 'ui', file: 'textarea.tsx' },\n },\n ],\n },\n {\n name: 'toggle',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/toggle'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/toggle.tsx',\n to: { folder: 'ui', file: 'toggle.tsx' },\n },\n ],\n },\n {\n name: 'toggle-group',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/toggle-group'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/toggle-group.tsx',\n to: { folder: 'ui', file: 'toggle-group.tsx' },\n },\n ],\n },\n {\n name: 'tooltip',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/tooltip'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/tooltip.tsx',\n to: { folder: 'ui', file: 'tooltip.tsx' },\n },\n ],\n },\n {\n name: 'typography',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/typography.tsx',\n to: { folder: 'ui', file: 'typography.tsx' },\n },\n ],\n },\n];\n","import { COMPONENTS } from './components';\n\nexport type Component = (typeof COMPONENTS)[number] & { icons?: string[] };\ntype ComponentName = (typeof COMPONENTS)[number]['name'];\n\nfunction getComponentDependencies(\n componentName: ComponentName,\n visited = new Set<ComponentName>()\n) {\n const component = COMPONENTS.find((comp) => comp.name === componentName);\n if (!component) return [];\n\n visited.add(componentName);\n\n let dependencies: ComponentName[] = component.dependencies.slice();\n\n component.dependencies.forEach((dependency) => {\n if (!visited.has(dependency)) {\n const childDependencies = getComponentDependencies(dependency, visited);\n dependencies = dependencies.concat(childDependencies);\n }\n });\n\n return dependencies;\n}\n\nexport const INVALID_COMPONENT_ERROR = 'invalid component';\n\nexport function getAllComponentsToWrite(componentNames: string[]): Component[] {\n const uniqueComponents = new Set<ComponentName>();\n\n if (\n componentNames.some((componentName) => !COMPONENTS.find((comp) => comp.name === componentName))\n ) {\n throw new Error(INVALID_COMPONENT_ERROR);\n }\n\n componentNames.forEach((componentName) => {\n const allDependencies = getComponentDependencies(componentName as ComponentName);\n allDependencies.unshift(componentName as never); // Add the component itself to the list\n allDependencies.forEach((dep) => {\n uniqueComponents.add(dep);\n });\n });\n\n return Array.from(uniqueComponents).map((dep) => {\n const comp = COMPONENTS.find((comp) => comp.name === dep);\n if (!comp) {\n throw new Error(INVALID_COMPONENT_ERROR);\n }\n return comp;\n });\n}\n","import { existsSync, promises as fs } from 'fs';\nimport path from 'path';\n\nexport async function copyFolder(\n src: string,\n dest: string,\n options: { ignore: string[]; renameTemplateFiles: boolean } = {\n ignore: [],\n renameTemplateFiles: false,\n }\n) {\n if (!existsSync(src)) {\n throw new Error(`Source folder does not exist: ${src}`);\n }\n\n if (!existsSync(dest)) {\n await fs.mkdir(dest, { recursive: true });\n }\n\n const entries = await fs.readdir(src, { withFileTypes: true });\n\n for (const entry of entries) {\n const srcPath = path.join(src, entry.name);\n const destPath = path.join(dest, entry.name);\n\n if (options.ignore.includes(entry.name)) {\n continue;\n }\n\n if (entry.isDirectory()) {\n await copyFolder(srcPath, destPath, options);\n } else if (entry.isFile()) {\n if (options.renameTemplateFiles && entry.name === 'gitignore-template') {\n await fs.copyFile(srcPath, path.join(dest, '.gitignore'));\n } else if (options.renameTemplateFiles && entry.name === 'npmrc-template') {\n await fs.copyFile(srcPath, path.join(dest, '.npmrc'));\n } else {\n await fs.copyFile(srcPath, destPath);\n }\n }\n }\n}\n","import { copyFolder } from '@/src/utils/copy-folder';\nimport { getConfig } from '@/src/utils/get-config';\nimport { handleError } from '@/src/utils/handle-error';\nimport { logger } from '@/src/utils/logger';\nimport { promptForConfig } from '@/src/utils/prompt-for-config';\nimport chalk from 'chalk';\nimport { execSync } from 'child_process';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport glob from 'fast-glob';\nimport { existsSync, promises as fs } from 'fs';\nimport ora, { Ora } from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\nimport { fileURLToPath } from 'url';\nimport { z } from 'zod';\n\nconst filePath = fileURLToPath(import.meta.url);\nconst fileDir = path.dirname(filePath);\n\nconst REQUIRED_DEPENDENCIES = [\n 'nativewind',\n 'expo-navigation-bar',\n 'tailwindcss-animate',\n 'class-variance-authority',\n 'clsx',\n 'tailwind-merge',\n 'react-native-svg',\n 'lucide-react-native',\n '@rn-primitives/portal',\n] as const;\n\nconst TEMPLATE_FILES = [\n 'tailwind.config.js',\n 'nativewind-env.d.ts',\n 'global.css',\n 'babel.config.js',\n 'metro.config.js',\n 'lib/utils.ts',\n 'lib/useColorScheme.tsx',\n 'lib/constants.ts',\n 'lib/android-navigation-bar.ts',\n 'lib/icons/iconWithClassName.ts',\n] as const;\n\nconst initOptionsSchema = z.object({\n cwd: z.string(),\n overwrite: z.boolean(),\n});\n\nexport const init = new Command()\n .name('init')\n .description('Initialize the required configuration for your React Native project')\n .option(\n '-c, --cwd <cwd>',\n 'the working directory. defaults to the current directory.',\n process.cwd()\n )\n .option('-o, --overwrite', 'overwrite existing files', false)\n .action(async (opts) => {\n try {\n const options = initOptionsSchema.parse(opts);\n const cwd = path.resolve(options.cwd);\n\n await validateProjectDirectory(cwd);\n await checkGitStatus(cwd);\n await initializeProject(cwd, options.overwrite);\n } catch (error) {\n handleError(error);\n }\n });\n\nasync function validateProjectDirectory(cwd: string) {\n if (existsSync(cwd) && existsSync(path.join(cwd, 'package.json'))) {\n const { option } = await prompts({\n type: 'select',\n name: 'option',\n message:\n 'Package.json found. How would you like to proceed? (Selecting \"Cancel\" will exit the process)',\n choices: [\n { title: 'Automatically configure your existing project', value: 'existing-project' },\n { title: 'Init new project', value: 'new-project' },\n { title: 'Cancel', value: 'cancel' },\n ],\n initial: false,\n });\n\n if (option === 'cancel') {\n logger.info('Installation cancelled.');\n process.exit(0);\n }\n\n if (option === 'existing-project') {\n return;\n }\n }\n\n const { projectName } = await prompts({\n type: 'text',\n name: 'projectName',\n message: `What is the name of your project?`,\n initial: 'starter-base',\n });\n\n const { packageManager } = await prompts({\n type: 'select',\n name: 'packageManager',\n message: 'Which package manager would you like to use?',\n choices: [\n { title: 'npm', value: 'npm' },\n { title: 'yarn', value: 'yarn' },\n { title: 'pnpm', value: 'pnpm' },\n { title: 'bun', value: 'bun' },\n ],\n });\n\n const spinner = ora(`Initializing ${projectName}...`).start();\n\n const projectPath = path.join(cwd, projectName);\n if (!existsSync(projectPath)) {\n await fs.mkdir(projectPath, { recursive: true });\n }\n\n const filesToIgnore = [];\n\n if (packageManager !== 'pnpm') {\n filesToIgnore.push('npmrc-template');\n }\n\n await copyFolder(path.join(fileDir, '../__generated/starter-base'), projectPath, {\n ignore: filesToIgnore,\n renameTemplateFiles: true,\n });\n\n await Promise.all([\n replaceAllInJsonFile(path.join(projectPath, 'app.json'), 'starter-base', projectName),\n replaceAllInJsonFile(path.join(projectPath, 'package.json'), '@rnr/starter-base', projectName),\n ]);\n\n spinner.start('Installing dependencies...');\n await execa(packageManager, ['install'], {\n cwd: projectPath,\n });\n spinner.text = 'Verifying and updating any invalid package versions if needed...';\n await execa('npx', ['expo', 'install', '--fix'], {\n cwd: projectPath,\n });\n\n spinner.succeed('New project initialized successfully!');\n console.log(`\\nTo get started, run the following commands:\\n`);\n console.log(chalk.cyan(`cd ${projectName}`));\n console.log(\n chalk.cyan(\n `${packageManager} ${packageManager === 'npm' || packageManager === 'bun' ? 'run ' : ''}dev`\n )\n );\n process.exit(0);\n}\n\nasync function replaceAllInJsonFile(path: string, searchValue: string, replaceValue: string) {\n try {\n if (!existsSync(path)) {\n logger.error(`The path ${path} does not exist.`);\n process.exit(1);\n }\n\n const jsonValue = await fs.readFile(path, 'utf8');\n const replacedValue = jsonValue.replaceAll(searchValue, replaceValue);\n\n await fs.writeFile(path, replacedValue);\n } catch (error) {\n handleError(error);\n }\n}\n\nasync function checkGitStatus(cwd: string) {\n if (await shouldPromptGitWarning(cwd)) {\n const { proceed } = await prompts({\n type: 'confirm',\n name: 'proceed',\n message:\n 'The Git repository is dirty (uncommitted changes). It is recommended to commit your changes before proceeding. Do you want to continue?',\n initial: false,\n });\n\n if (!proceed) {\n logger.info('Installation cancelled.');\n process.exit(0);\n }\n }\n}\n\nasync function shouldPromptGitWarning(cwd: string): Promise<boolean> {\n try {\n execSync('git rev-parse --is-inside-work-tree', { cwd });\n const status = execSync('git status --porcelain', { cwd }).toString();\n return !!status;\n } catch (error) {\n return false;\n }\n}\n\nasync function initializeProject(cwd: string, overwrite: boolean) {\n const spinner = ora(`Initializing project...`).start();\n\n try {\n let config = await getConfig(cwd);\n\n if (!config) {\n spinner.stop();\n config = await promptForConfig(cwd);\n spinner.start();\n }\n\n const templatesDir = path.join(fileDir, '../__generated/starter-base');\n\n await installDependencies(cwd, spinner);\n await updateTsConfig(cwd, config, spinner);\n\n spinner.text = 'Adding config and utility files...';\n for (const file of TEMPLATE_FILES) {\n await copyTemplateFile(file, templatesDir, cwd, spinner, overwrite);\n }\n\n await updateLayoutFile(cwd, spinner);\n\n spinner.succeed('Initialization completed successfully!');\n } catch (error) {\n spinner.fail('Initialization failed');\n handleError(error);\n process.exit(1);\n }\n}\n\nasync function installDependencies(cwd: string, spinner: Ora) {\n try {\n spinner.text = 'Installing dependencies...';\n await execa('npx', ['expo', 'install', ...REQUIRED_DEPENDENCIES], {\n cwd,\n stdio: 'inherit',\n });\n spinner.text = 'Dependencies installed successfully';\n } catch (error) {\n spinner.fail('Failed to install dependencies');\n handleError(error);\n process.exit(1);\n }\n}\n\nconst NON_PATH_ALIAS_BASES = ['', '.', '/'];\n\nasync function updateTsConfig(cwd: string, config: any, spinner: Ora) {\n try {\n const tsconfigPath = path.join(cwd, 'tsconfig.json');\n const tsconfig = existsSync(tsconfigPath)\n ? JSON.parse(await fs.readFile(tsconfigPath, 'utf8'))\n : {};\n\n const componentBase = config.aliases.components.split('/')[0];\n const libBase = config.aliases.lib.split('/')[0];\n\n if (NON_PATH_ALIAS_BASES.includes(componentBase) || NON_PATH_ALIAS_BASES.includes(libBase)) {\n return;\n }\n\n const tsconfigPaths = tsconfig.compilerOptions?.paths ?? {};\n\n if (\n tsconfigPaths[`${componentBase}/*`]?.[0] === '*' &&\n tsconfigPaths[`${libBase}/*`]?.[0] === '*'\n ) {\n spinner.succeed('Path aliases already configured');\n return;\n }\n\n spinner.text = 'Updating path aliases...';\n\n tsconfig.compilerOptions = {\n ...tsconfig.compilerOptions,\n baseUrl: '.',\n paths: {\n [`${componentBase}/*`]: ['*'],\n [`${libBase}/*`]: ['*'],\n ...tsconfig.compilerOptions?.paths,\n },\n };\n\n await fs.writeFile(tsconfigPath, JSON.stringify(tsconfig, null, 2));\n } catch (error) {\n spinner.fail('Failed to update tsconfig.json');\n handleError(error);\n }\n}\n\nasync function copyTemplateFile(\n file: string,\n templatesDir: string,\n targetDir: string,\n spinner: Ora,\n overwriteFlag: boolean\n) {\n const targetPath = path.join(targetDir, file);\n spinner.stop();\n\n if (existsSync(targetPath)) {\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n file\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n return;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(file)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped`);\n return;\n }\n }\n\n spinner.start(`Installing ${file}...`);\n await fs.mkdir(path.dirname(targetPath), { recursive: true });\n await fs.copyFile(path.join(templatesDir, file), targetPath);\n}\n\nasync function updateLayoutFile(cwd: string, spinner: Ora) {\n try {\n const layoutFiles = await glob(\n ['app/_layout.{ts,tsx,js,jsx}', '(app)/_layout.{ts,tsx,js,jsx}'],\n {\n cwd,\n ignore: ['node_modules/**'],\n }\n );\n\n if (!layoutFiles.length) {\n spinner.warn('Could not find the root _layout file');\n return;\n }\n\n const layoutPath = path.join(cwd, layoutFiles[0]);\n const content = await fs.readFile(layoutPath, 'utf8');\n\n if (!content.includes('import \"../global.css\"')) {\n spinner.text = 'Updating layout file...';\n await fs.writeFile(layoutPath, `import \"../global.css\";\\n${content}`);\n spinner.succeed(`Updated ${layoutFiles[0]} with global CSS import`);\n }\n } catch (error) {\n spinner.fail('Failed to update layout file');\n handleError(error);\n }\n}\n","#!/usr/bin/env node\nimport { add } from '@/src/commands/add';\nimport { init } from '@/src/commands/init';\n\nimport { Command } from 'commander';\n\nprocess.on('SIGINT', () => process.exit(0));\nprocess.on('SIGTERM', () => process.exit(0));\n\nasync function main() {\n const program = new Command()\n .name('@react-native-reusables/cli')\n .description('add components and dependencies to your project');\n\n program.addCommand(add);\n program.addCommand(init);\n\n program.parse();\n}\n\nmain();\n"],"mappings":";AAAA,OAAS,mBAAAA,OAAuD,iBAEhE,eAAsBC,EACpBC,EACAC,EACA,CACA,OAAOH,GAAgBG,EAAO,gBAAiBA,EAAO,KAAK,EACzDD,EACA,OACA,IAAM,GACN,CAAC,MAAO,MAAM,CAChB,CACF,CCXA,OAAS,eAAAE,OAAmB,cAC5B,OAAS,cAAAC,OAAkB,iBAC3B,OAAS,KAAAC,MAAS,MAEX,IAAMC,EAAqB,eACrBC,EAAc,QAErBC,GAAWL,GAAY,aAAc,CACzC,aAAc,CAAC,iBAAiB,CAClC,CAAC,EAEYM,EAAkBJ,EAAE,OAAO,CACtC,QAASA,EAAE,OAAO,CAChB,WAAYA,EAAE,OAAO,EACrB,IAAKA,EAAE,OAAO,CAChB,CAAC,CACH,CAAC,EAIYK,GAAeD,EAAgB,OAAO,CACjD,cAAeJ,EAAE,OAAO,CACtB,IAAKA,EAAE,OAAO,EACd,WAAYA,EAAE,OAAO,CACvB,CAAC,CACH,CAAC,EAID,eAAsBM,EAAUC,EAAa,CAC3C,IAAMC,EAAS,MAAMC,GAAaF,CAAG,EAErC,OAAKC,EAIE,MAAME,EAAmBH,EAAKC,CAAM,EAHlC,IAIX,CAEA,eAAsBE,EAAmBH,EAAaC,EAAmB,CAEvE,IAAMG,EAAW,MAAMZ,GAAWQ,CAAG,EAErC,GAAII,EAAS,aAAe,SAC1B,MAAM,IAAI,MAAM,iCAAiCA,EAAS,SAAW,KAAK,KAAK,CAAC,EAGlF,OAAON,GAAa,MAAM,CACxB,GAAGG,EACH,cAAe,CACb,IAAK,MAAMI,EAAcJ,EAAO,QAAQ,IAAQG,CAAQ,EACxD,WAAY,MAAMC,EAAcJ,EAAO,QAAQ,WAAeG,CAAQ,CACxE,CACF,CAAC,CACH,CAEA,eAAsBF,GAAaF,EAAwC,CACzE,GAAI,CACF,IAAMM,EAAe,MAAMV,GAAS,OAAOI,CAAG,EAE9C,OAAKM,EAIET,EAAgB,MAAMS,EAAa,MAAM,EAHvC,IAIX,MAAE,CACA,MAAM,IAAI,MAAM,kCAAkCN,oBAAsB,CAC1E,CACF,CCrEA,OAAS,UAAAO,OAAc,YAEvB,eAAsBC,EACpBC,EAC0C,CAC1C,IAAMC,EAAiB,MAAMH,GAAO,CAAE,aAAc,GAAM,IAAKE,CAAU,CAAC,EAE1E,OAAIC,IAAmB,aAAqB,OACxCA,IAAmB,SAAiB,OACpCA,IAAmB,MAAc,MAE9BA,GAAkB,KAC3B,CCZA,OAAOC,MAAW,QAEX,IAAMC,EAAS,CACpB,SAASC,EAAiB,CACxB,QAAQ,IAAIF,EAAM,IAAI,GAAGE,CAAI,CAAC,CAChC,EACA,QAAQA,EAAiB,CACvB,QAAQ,IAAIF,EAAM,OAAO,GAAGE,CAAI,CAAC,CACnC,EACA,QAAQA,EAAiB,CACvB,QAAQ,IAAIF,EAAM,KAAK,GAAGE,CAAI,CAAC,CACjC,EACA,WAAWA,EAAiB,CAC1B,QAAQ,IAAIF,EAAM,MAAM,GAAGE,CAAI,CAAC,CAClC,EACA,OAAQ,CACN,QAAQ,IAAI,EAAE,CAChB,CACF,EChBO,SAASC,EAAYC,EAAgB,CACtC,OAAOA,GAAU,WACnBC,EAAO,MAAMD,CAAK,EAClB,QAAQ,KAAK,CAAC,GAGZA,aAAiB,QACnBC,EAAO,MAAMD,EAAM,OAAO,EAC1B,QAAQ,KAAK,CAAC,GAGhBC,EAAO,MAAM,yCAAyC,EACtD,QAAQ,KAAK,CAAC,CAChB,CCRA,OAAOC,OAAW,QAClB,OAAS,YAAYC,OAAU,KAC/B,OAAOC,OAAS,MAChB,OAAOC,OAAU,OACjB,OAAOC,MAAa,UAEpB,eAAsBC,EAAgBC,EAAa,CACjD,IAAMC,EAAaC,GAAiBR,GAAM,KAAKQ,CAAI,EAE7CC,EAAU,MAAML,EAAQ,CAC5B,CACE,KAAM,OACN,KAAM,aACN,QAAS,kCAAkCG,EAAU,YAAY,KACjE,QAASG,CACX,EACA,CACE,KAAM,OACN,KAAM,MACN,QAAS,kCAAkCH,EAAU,KAAK,KAC1D,QAASI,CACX,CACF,CAAC,EAEKC,EAASC,EAAgB,MAAM,CACnC,QAAS,CACP,IAAKJ,EAAQ,KAAOC,EACpB,WAAYD,EAAQ,YAAcE,CACpC,CACF,CAAC,EAEK,CAAE,QAAAG,CAAQ,EAAI,MAAMV,EAAQ,CAChC,KAAM,UACN,KAAM,UACN,QAAS,0BAA0BG,EAAU,iBAAiB,cAC9D,QAAS,EACX,CAAC,EAED,GAAIO,EAAS,CACXC,EAAO,KAAK,EAAE,EACd,IAAMC,EAAUd,GAAI,4BAA4B,EAAE,MAAM,EAClDe,EAAad,GAAK,QAAQG,EAAK,iBAAiB,EACtD,MAAML,GAAG,UAAUgB,EAAY,KAAK,UAAUL,EAAQ,KAAM,CAAC,EAAG,MAAM,EACtEI,EAAQ,QAAQ,EAGlB,OAAO,MAAME,EAAmBZ,EAAKM,CAAM,CAC7C,CCjDA,OAAOO,MAAW,QAClB,OAAS,WAAAC,OAAe,YACxB,OAAS,SAAAC,OAAa,QACtB,OAAS,cAAAC,EAAY,YAAYC,MAAU,KAC3C,OAAOC,OAAkB,MACzB,OAAOC,MAAU,OACjB,OAAOC,MAAa,UACpB,OAAS,iBAAAC,OAAqB,MAC9B,OAAS,KAAAC,MAAS,MCbX,IAAMC,EAAa,CACxB,CACE,KAAM,YACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,aAAa,EACrB,YAAa,CAAC,0BAA0B,EACxC,MAAO,CACL,CACE,KAAM,gEACN,GAAI,CACF,OAAQ,KACR,KAAM,eACR,CACF,CACF,CACF,EACA,CACE,KAAM,QACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,EACd,MAAO,CACL,CACE,KAAM,4DACN,GAAI,CACF,OAAQ,KACR,KAAM,WACR,CACF,CACF,CACF,EACA,CACE,KAAM,eACN,aAAc,CAAC,SAAU,MAAM,EAC/B,MAAO,CAAC,EACR,YAAa,CAAC,6BAA6B,EAC3C,MAAO,CACL,CACE,KAAM,mEACN,GAAI,CACF,OAAQ,KACR,KAAM,kBACR,CACF,CACF,CACF,EACA,CACE,KAAM,eACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,6BAA6B,EAC3C,MAAO,CACL,CACE,KAAM,mEACN,GAAI,CACF,OAAQ,KACR,KAAM,kBACR,CACF,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,uBAAuB,EACrC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CACF,OAAQ,KACR,KAAM,YACR,CACF,CACF,CACF,EACA,CACE,KAAM,QACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,sBAAuB,sBAAsB,EAC3D,MAAO,CACL,CACE,KAAM,4DACN,GAAI,CACF,OAAQ,KACR,KAAM,WACR,CACF,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,sBAAsB,EACpC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CACF,OAAQ,KACR,KAAM,YACR,CACF,CACF,CACF,EACA,CACE,KAAM,OACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,sBAAsB,EACpC,MAAO,CACL,CACE,KAAM,2DACN,GAAI,CACF,OAAQ,KACR,KAAM,UACR,CACF,CACF,CACF,EACA,CACE,KAAM,WACN,aAAc,CAAC,EACf,MAAO,CAAC,OAAO,EACf,YAAa,CAAC,yBAAyB,EACvC,MAAO,CACL,CACE,KAAM,+DACN,GAAI,CACF,OAAQ,KACR,KAAM,cACR,CACF,CACF,CACF,EACA,CACE,KAAM,cACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,4BAA4B,EAC1C,MAAO,CACL,CACE,KAAM,kEACN,GAAI,CACF,OAAQ,KACR,KAAM,iBACR,CACF,CACF,CACF,EACA,CACE,KAAM,eACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,QAAS,cAAe,eAAgB,WAAW,EAC3D,YAAa,CAAC,6BAA6B,EAC3C,MAAO,CACL,CACE,KAAM,mEACN,GAAI,CACF,OAAQ,KACR,KAAM,kBACR,CACF,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,EACf,MAAO,CAAC,GAAG,EACX,YAAa,CAAC,uBAAuB,EACrC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CACF,OAAQ,KACR,KAAM,YACR,CACF,CACF,CACF,EACA,CACE,KAAM,gBACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,QAAS,cAAe,eAAgB,WAAW,EAC3D,YAAa,CAAC,8BAA8B,EAC5C,MAAO,CACL,CACE,KAAM,oEACN,GAAI,CACF,OAAQ,KACR,KAAM,mBACR,CACF,CACF,CACF,EACA,CACE,KAAM,aACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,2BAA2B,EACzC,MAAO,CACL,CACE,KAAM,iEACN,GAAI,CACF,OAAQ,KACR,KAAM,gBACR,CACF,CACF,CACF,EACA,CACE,KAAM,QACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,EACd,MAAO,CACL,CACE,KAAM,4DACN,GAAI,CACF,OAAQ,KACR,KAAM,WACR,CACF,CACF,CACF,EACA,CACE,KAAM,QACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,sBAAsB,EACpC,MAAO,CACL,CACE,KAAM,4DACN,GAAI,CACF,OAAQ,KACR,KAAM,WACR,CACF,CACF,CACF,EACA,CACE,KAAM,UACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,QAAS,cAAe,eAAgB,WAAW,EAC3D,YAAa,CAAC,wBAAwB,EACtC,MAAO,CACL,CACE,KAAM,8DACN,GAAI,CACF,OAAQ,KACR,KAAM,aACR,CACF,CACF,CACF,EACA,CACE,KAAM,kBACN,aAAc,CAAC,EACf,MAAO,CAAC,aAAa,EACrB,YAAa,CAAC,gCAAgC,EAC9C,MAAO,CACL,CACE,KAAM,sEACN,GAAI,CACF,OAAQ,KACR,KAAM,qBACR,CACF,CACF,CACF,EACA,CACE,KAAM,UACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,wBAAwB,EACtC,MAAO,CACL,CACE,KAAM,8DACN,GAAI,CACF,OAAQ,KACR,KAAM,aACR,CACF,CACF,CACF,EACA,CACE,KAAM,WACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,yBAAyB,EACvC,MAAO,CACL,CACE,KAAM,+DACN,GAAI,CACF,OAAQ,KACR,KAAM,cACR,CACF,CACF,CACF,EACA,CACE,KAAM,cACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,4BAA4B,EAC1C,MAAO,CACL,CACE,KAAM,kEACN,GAAI,CACF,OAAQ,KACR,KAAM,iBACR,CACF,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,EACf,MAAO,CAAC,QAAS,cAAe,WAAW,EAC3C,YAAa,CAAC,uBAAuB,EACrC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CACF,OAAQ,KACR,KAAM,YACR,CACF,CACF,CACF,EACA,CACE,KAAM,YACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,0BAA0B,EACxC,MAAO,CACL,CACE,KAAM,gEACN,GAAI,CACF,OAAQ,KACR,KAAM,eACR,CACF,CACF,CACF,EACA,CACE,KAAM,WACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,EACd,MAAO,CACL,CACE,KAAM,+DACN,GAAI,CACF,OAAQ,KACR,KAAM,cACR,CACF,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,uBAAuB,EACrC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CACF,OAAQ,KACR,KAAM,YACR,CACF,CACF,CACF,EACA,CACE,KAAM,QACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,sBAAsB,EACpC,MAAO,CACL,CACE,KAAM,4DACN,GAAI,CACF,OAAQ,KACR,KAAM,WACR,CACF,CACF,CACF,EACA,CACE,KAAM,OACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,qBAAqB,EACnC,MAAO,CACL,CACE,KAAM,2DACN,GAAI,CACF,OAAQ,KACR,KAAM,UACR,CACF,CACF,CACF,EACA,CACE,KAAM,OACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,sBAAuB,sBAAsB,EAC3D,MAAO,CACL,CACE,KAAM,2DACN,GAAI,CAAE,OAAQ,KAAM,KAAM,UAAW,CACvC,CACF,CACF,EACA,CACE,KAAM,WACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,EACd,MAAO,CACL,CACE,KAAM,+DACN,GAAI,CAAE,OAAQ,KAAM,KAAM,cAAe,CAC3C,CACF,CACF,EACA,CACE,KAAM,SACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,uBAAuB,EACrC,MAAO,CACL,CACE,KAAM,6DACN,GAAI,CAAE,OAAQ,KAAM,KAAM,YAAa,CACzC,CACF,CACF,EACA,CACE,KAAM,eACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,6BAA6B,EAC3C,MAAO,CACL,CACE,KAAM,mEACN,GAAI,CAAE,OAAQ,KAAM,KAAM,kBAAmB,CAC/C,CACF,CACF,EACA,CACE,KAAM,UACN,aAAc,CAAC,MAAM,EACrB,MAAO,CAAC,EACR,YAAa,CAAC,wBAAwB,EACtC,MAAO,CACL,CACE,KAAM,8DACN,GAAI,CAAE,OAAQ,KAAM,KAAM,aAAc,CAC1C,CACF,CACF,EACA,CACE,KAAM,aACN,aAAc,CAAC,EACf,MAAO,CAAC,EACR,YAAa,CAAC,sBAAuB,sBAAsB,EAC3D,MAAO,CACL,CACE,KAAM,iEACN,GAAI,CAAE,OAAQ,KAAM,KAAM,gBAAiB,CAC7C,CACF,CACF,CACF,ECzdA,SAASC,EACPC,EACAC,EAAU,IAAI,IACd,CACA,IAAMC,EAAYC,EAAW,KAAMC,GAASA,EAAK,OAASJ,CAAa,EACvE,GAAI,CAACE,EAAW,MAAO,CAAC,EAExBD,EAAQ,IAAID,CAAa,EAEzB,IAAIK,EAAgCH,EAAU,aAAa,MAAM,EAEjE,OAAAA,EAAU,aAAa,QAASI,GAAe,CAC7C,GAAI,CAACL,EAAQ,IAAIK,CAAU,EAAG,CAC5B,IAAMC,EAAoBR,EAAyBO,EAAYL,CAAO,EACtEI,EAAeA,EAAa,OAAOE,CAAiB,EAExD,CAAC,EAEMF,CACT,CAEO,IAAMG,EAA0B,oBAEhC,SAASC,EAAwBC,EAAuC,CAC7E,IAAMC,EAAmB,IAAI,IAE7B,GACED,EAAe,KAAMV,GAAkB,CAACG,EAAW,KAAMC,GAASA,EAAK,OAASJ,CAAa,CAAC,EAE9F,MAAM,IAAI,MAAMQ,CAAuB,EAGzC,OAAAE,EAAe,QAASV,GAAkB,CACxC,IAAMY,EAAkBb,EAAyBC,CAA8B,EAC/EY,EAAgB,QAAQZ,CAAsB,EAC9CY,EAAgB,QAASC,GAAQ,CAC/BF,EAAiB,IAAIE,CAAG,CAC1B,CAAC,CACH,CAAC,EAEM,MAAM,KAAKF,CAAgB,EAAE,IAAKE,GAAQ,CAC/C,IAAMT,EAAOD,EAAW,KAAMC,GAASA,EAAK,OAASS,CAAG,EACxD,GAAI,CAACT,EACH,MAAM,IAAI,MAAMI,CAAuB,EAEzC,OAAOJ,CACT,CAAC,CACH,CFnCA,IAAMU,GAAWC,GAAc,YAAY,GAAG,EACxCC,EAAUC,EAAK,QAAQH,EAAQ,EAE/BI,GAAmBC,EAAE,OAAO,CAChC,WAAYA,EAAE,MAAMA,EAAE,OAAO,CAAC,EAAE,SAAS,EACzC,UAAWA,EAAE,QAAQ,EACrB,IAAKA,EAAE,OAAO,EACd,KAAMA,EAAE,OAAO,EAAE,SAAS,CAC5B,CAAC,EAEYC,EAAM,IAAIC,GAAQ,EAC5B,KAAK,KAAK,EACV,YAAY,gCAAgC,EAC5C,SAAS,kBAAmB,uBAAuB,EACnD,OAAO,kBAAmB,4BAA6B,EAAK,EAC5D,OACC,kBACA,4DACA,QAAQ,IAAI,CACd,EACC,OAAO,MAAOC,EAAYC,IAAS,CAClC,GAAI,CACF,IAAMC,EAAUN,GAAiB,MAAM,CACrC,WAAAI,EACA,GAAGC,CACL,CAAC,EAEKE,EAAMR,EAAK,QAAQO,EAAQ,GAAG,EAE/BE,EAAWD,CAAG,IACjBE,EAAO,MAAM,YAAYF,qCAAuC,EAChE,QAAQ,KAAK,CAAC,GAGhB,IAAIG,EAAS,MAAMC,EAAUJ,CAAG,EAE3BG,IACHA,EAAS,MAAME,EAAgBL,CAAG,GAGpC,IAAIM,EAAoCP,EAAQ,YAAc,CAAC,EAC/D,GAAI,CAACO,GAAoB,OAAQ,CAC/B,GAAM,CAAE,WAAAT,CAAW,EAAI,MAAMU,EAAQ,CACnC,KAAM,cACN,KAAM,aACN,QAAS,0CACT,KAAM,qDACN,aAAc,GACd,QAASC,EAAW,IAAKC,IAAW,CAClC,MAAOA,EAAM,KACb,MAAOA,EAAM,KACb,SAAU,EACZ,EAAE,CACJ,CAAC,EACDH,EAAqBT,EAGlBS,GAAoB,SACvBJ,EAAO,KAAK,kCAAkC,EAC9C,QAAQ,KAAK,CAAC,GAGhB,IAAMQ,EAAUC,GAAI,0BAA0B,EAAE,MAAM,EAElDC,EAAsC,CAAC,EAC3C,GAAI,CACFA,EAAoBC,EAAwBP,CAAkB,CAChE,OAASQ,EAAP,CACIA,aAAe,OAASA,EAAI,UAAYC,IAC1Cb,EAAO,MACL,yBAAyBI,EACtB,OAAQU,GAAc,CAACR,EAAW,KAAMC,IAAUA,GAAM,OAASO,CAAS,CAAC,EAC3E,KAAK,IAAI,GACd,EACA,QAAQ,KAAK,CAAC,GAEhBd,EAAO,MAAMY,CAAG,CAClB,CAEA,IAAMG,EAA6B,CAAC,EAEpC,QAAWC,KAAQN,EACjBF,EAAQ,KAAO,cAAcQ,EAAK,UAElC,MAAMC,GAAWD,EAAMA,EAAK,MAAOf,EAAQO,EAASX,EAAQ,SAAS,EAErEkB,EAAY,KAAK,GAAGC,EAAK,WAAW,EAGtC,IAAME,EAAiB,MAAMC,EAAkBrB,CAAG,EAE5CsB,EAAoB,MAAM,KAAK,IAAI,IAAIL,CAAW,CAAC,EAErDK,EAAkB,SACpBZ,EAAQ,KAAO,cAAcY,EAAkB,KAAK,IAAI,OACxD,MAAMC,GACJH,EACA,CAACA,IAAmB,MAAQ,UAAY,MAAO,GAAGE,CAAiB,EACnE,CACE,IAAAtB,CACF,CACF,GAEFU,EAAQ,QAAQ,OAAO,CACzB,OAASc,EAAP,CACAC,EAAYD,CAAK,CACnB,CACF,CAAC,EAEH,eAAeL,GACbD,EACAQ,EACAvB,EACAO,EACAiB,EACA,CACA,QAAWC,KAAYF,EAAO,CAC5B,IAAMG,EAAYrC,EAAK,KAAKW,EAAO,cAAc,WAAYyB,EAAS,GAAG,MAAM,EAO/E,GANK3B,EAAW4B,CAAS,GACvB,MAAMC,EAAG,MAAMD,EAAW,CAAE,UAAW,EAAK,CAAC,EAG/CnB,EAAQ,KAAK,EAETT,EAAWT,EAAK,KAAKqC,EAAWD,EAAS,GAAG,IAAI,CAAC,EAAG,CACtD,IAAMvC,EAAW,CAACuC,EAAS,GAAG,OAAQA,EAAS,GAAG,IAAI,EAAE,KAAK,GAAG,EAChE,GAAI,CAACD,EAAe,CAClBzB,EAAO,KACL,wBAAwB6B,EAAM,OAC5B1C,CACF,6CAA6C0C,EAAM,MAAM,aAAa,SACxE,EACA,SAGF,GAAM,CAAE,UAAAC,CAAU,EAAI,MAAMzB,EAAQ,CAClC,KAAM,UACN,KAAM,YACN,QAAS,wBAAwBwB,EAAM,OAAO1C,CAAQ,kCACtD,QAAS,EACX,CAAC,EAED,GAAI,CAAC2C,EAAW,CACd9B,EAAO,KAAK,SAAS,EACrB,UAIJQ,EAAQ,MAAM,cAAcQ,EAAK,SAAS,EAC1C,IAAMe,EAAeL,EAAS,SAC1BpC,EAAK,KAAKD,EAAS,4BAA6BqC,EAAS,QAAQ,EACjEpC,EAAK,KAAKD,EAAS,4BAA6BqC,EAAS,GAAG,OAAQA,EAAS,GAAG,IAAI,EACxF,GAAI,CACF,IAAMM,EAAU,MAAMJ,EAAG,SAAStC,EAAK,QAAQyC,CAAY,EAAG,MAAM,EACpE,MAAMH,EAAG,UACPtC,EAAK,KAAKqC,EAAWD,EAAS,GAAG,IAAI,EACrCO,GAAWD,EAAS/B,EAAO,QAAQ,WAAYA,EAAO,QAAQ,GAAG,CACnE,CACF,OAASqB,EAAP,CACAC,EAAYD,CAAK,CACnB,EAGF,QAAWY,KAAQlB,EAAK,OAAS,CAAC,EAAG,CACnC,IAAMW,EAAYrC,EAAK,QAAQW,EAAO,cAAc,IAAK,OAAO,EAChE,GAAI,CAACF,EAAW4B,CAAS,EAAG,CAC1B,MAAMC,EAAG,MAAMD,EAAW,CAAE,UAAW,EAAK,CAAC,EAC7C,GAAI,CACF,MAAMC,EAAG,UACPtC,EAAK,KAAKqC,EAAW,sBAAsB,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EACF,CACF,OAASL,EAAP,CACAC,EAAYD,CAAK,CACnB,EAGF,GAAIvB,EAAWT,EAAK,KAAKqC,EAAW,GAAGO,OAAU,CAAC,EAAG,CACnD,IAAM/C,EAAWG,EAAK,KAAKqC,EAAW,GAAGO,OAAU,EACnD,GAAI,CAACT,EAAe,CAClBzB,EAAO,KACL,wBAAwB6B,EAAM,OAC5B,GAAGK,OACL,6CAA6CL,EAAM,MAAM,aAAa,SACxE,EACA,SAGF,GAAM,CAAE,UAAAC,CAAU,EAAI,MAAMzB,EAAQ,CAClC,KAAM,UACN,KAAM,YACN,QAAS,wBAAwBwB,EAAM,OAAO1C,CAAQ,kCACtD,QAAS,EACX,CAAC,EAED,GAAI,CAAC2C,EAAW,CACd9B,EAAO,KAAK,WAAWkC,OAAU,EACjC,UAIJ1B,EAAQ,MAAM,cAAc0B,WAAc,EAE1C,GAAI,CACF,MAAMN,EAAG,UACPtC,EAAK,KAAKqC,EAAW,GAAGO,OAAU,EAClC,YAAYA;AAAA;AAAA,oBAAmHA;AAAA,WAAoBA,MACrJ,CACF,OAASZ,EAAP,CACAC,EAAYD,CAAK,CACnB,EAEJ,CAEA,SAASW,GAAWE,EAAiBC,EAAyBC,EAAkB,CAC9E,OAAOF,EACJ,QAAQ,eAAgB,GAAGC,iBAA+B,EAC1D,QAAQ,SAAU,GAAGA,WAAyB,EAC9C,WAAW,mBAAoBA,CAAe,EAC9C,WAAW,YAAaC,CAAQ,CACrC,CG7OA,OAAS,cAAAC,EAAY,YAAYC,MAAU,KAC3C,OAAOC,MAAU,OAEjB,eAAsBC,EACpBC,EACAC,EACAC,EAA8D,CAC5D,OAAQ,CAAC,EACT,oBAAqB,EACvB,EACA,CACA,GAAI,CAACN,EAAWI,CAAG,EACjB,MAAM,IAAI,MAAM,iCAAiCA,GAAK,EAGnDJ,EAAWK,CAAI,GAClB,MAAMJ,EAAG,MAAMI,EAAM,CAAE,UAAW,EAAK,CAAC,EAG1C,IAAME,EAAU,MAAMN,EAAG,QAAQG,EAAK,CAAE,cAAe,EAAK,CAAC,EAE7D,QAAWI,KAASD,EAAS,CAC3B,IAAME,EAAUP,EAAK,KAAKE,EAAKI,EAAM,IAAI,EACnCE,EAAWR,EAAK,KAAKG,EAAMG,EAAM,IAAI,EAEvCF,EAAQ,OAAO,SAASE,EAAM,IAAI,IAIlCA,EAAM,YAAY,EACpB,MAAML,EAAWM,EAASC,EAAUJ,CAAO,EAClCE,EAAM,OAAO,IAClBF,EAAQ,qBAAuBE,EAAM,OAAS,qBAChD,MAAMP,EAAG,SAASQ,EAASP,EAAK,KAAKG,EAAM,YAAY,CAAC,EAC/CC,EAAQ,qBAAuBE,EAAM,OAAS,iBACvD,MAAMP,EAAG,SAASQ,EAASP,EAAK,KAAKG,EAAM,QAAQ,CAAC,EAEpD,MAAMJ,EAAG,SAASQ,EAASC,CAAQ,IAI3C,CCpCA,OAAOC,MAAW,QAClB,OAAS,YAAAC,MAAgB,gBACzB,OAAS,WAAAC,OAAe,YACxB,OAAS,SAAAC,MAAa,QACtB,OAAOC,OAAU,YACjB,OAAS,cAAAC,EAAY,YAAYC,MAAU,KAC3C,OAAOC,MAAkB,MACzB,OAAOC,MAAU,OACjB,OAAOC,MAAa,UACpB,OAAS,iBAAAC,OAAqB,MAC9B,OAAS,KAAAC,MAAS,MAElB,IAAMC,GAAWF,GAAc,YAAY,GAAG,EACxCG,EAAUL,EAAK,QAAQI,EAAQ,EAE/BE,GAAwB,CAC5B,aACA,sBACA,sBACA,2BACA,OACA,iBACA,mBACA,sBACA,uBACF,EAEMC,GAAiB,CACrB,qBACA,sBACA,aACA,kBACA,kBACA,eACA,yBACA,mBACA,gCACA,gCACF,EAEMC,GAAoBL,EAAE,OAAO,CACjC,IAAKA,EAAE,OAAO,EACd,UAAWA,EAAE,QAAQ,CACvB,CAAC,EAEYM,GAAO,IAAIf,GAAQ,EAC7B,KAAK,MAAM,EACX,YAAY,qEAAqE,EACjF,OACC,kBACA,4DACA,QAAQ,IAAI,CACd,EACC,OAAO,kBAAmB,2BAA4B,EAAK,EAC3D,OAAO,MAAOgB,GAAS,CACtB,GAAI,CACF,IAAMC,EAAUH,GAAkB,MAAME,CAAI,EACtCE,EAAMZ,EAAK,QAAQW,EAAQ,GAAG,EAEpC,MAAME,GAAyBD,CAAG,EAClC,MAAME,GAAeF,CAAG,EACxB,MAAMG,GAAkBH,EAAKD,EAAQ,SAAS,CAChD,OAASK,EAAP,CACAC,EAAYD,CAAK,CACnB,CACF,CAAC,EAEH,eAAeH,GAAyBD,EAAa,CACnD,GAAIf,EAAWe,CAAG,GAAKf,EAAWG,EAAK,KAAKY,EAAK,cAAc,CAAC,EAAG,CACjE,GAAM,CAAE,OAAAM,CAAO,EAAI,MAAMjB,EAAQ,CAC/B,KAAM,SACN,KAAM,SACN,QACE,gGACF,QAAS,CACP,CAAE,MAAO,gDAAiD,MAAO,kBAAmB,EACpF,CAAE,MAAO,mBAAoB,MAAO,aAAc,EAClD,CAAE,MAAO,SAAU,MAAO,QAAS,CACrC,EACA,QAAS,EACX,CAAC,EAOD,GALIiB,IAAW,WACbC,EAAO,KAAK,yBAAyB,EACrC,QAAQ,KAAK,CAAC,GAGZD,IAAW,mBACb,OAIJ,GAAM,CAAE,YAAAE,CAAY,EAAI,MAAMnB,EAAQ,CACpC,KAAM,OACN,KAAM,cACN,QAAS,oCACT,QAAS,cACX,CAAC,EAEK,CAAE,eAAAoB,CAAe,EAAI,MAAMpB,EAAQ,CACvC,KAAM,SACN,KAAM,iBACN,QAAS,+CACT,QAAS,CACP,CAAE,MAAO,MAAO,MAAO,KAAM,EAC7B,CAAE,MAAO,OAAQ,MAAO,MAAO,EAC/B,CAAE,MAAO,OAAQ,MAAO,MAAO,EAC/B,CAAE,MAAO,MAAO,MAAO,KAAM,CAC/B,CACF,CAAC,EAEKqB,EAAUvB,EAAI,gBAAgBqB,MAAgB,EAAE,MAAM,EAEtDG,EAAcvB,EAAK,KAAKY,EAAKQ,CAAW,EACzCvB,EAAW0B,CAAW,GACzB,MAAMzB,EAAG,MAAMyB,EAAa,CAAE,UAAW,EAAK,CAAC,EAGjD,IAAMC,EAAgB,CAAC,EAEnBH,IAAmB,QACrBG,EAAc,KAAK,gBAAgB,EAGrC,MAAMC,EAAWzB,EAAK,KAAKK,EAAS,6BAA6B,EAAGkB,EAAa,CAC/E,OAAQC,EACR,oBAAqB,EACvB,CAAC,EAED,MAAM,QAAQ,IAAI,CAChBE,EAAqB1B,EAAK,KAAKuB,EAAa,UAAU,EAAG,eAAgBH,CAAW,EACpFM,EAAqB1B,EAAK,KAAKuB,EAAa,cAAc,EAAG,oBAAqBH,CAAW,CAC/F,CAAC,EAEDE,EAAQ,MAAM,4BAA4B,EAC1C,MAAM3B,EAAM0B,EAAgB,CAAC,SAAS,EAAG,CACvC,IAAKE,CACP,CAAC,EACDD,EAAQ,KAAO,mEACf,MAAM3B,EAAM,MAAO,CAAC,OAAQ,UAAW,OAAO,EAAG,CAC/C,IAAK4B,CACP,CAAC,EAEDD,EAAQ,QAAQ,uCAAuC,EACvD,QAAQ,IAAI;AAAA;AAAA,CAAiD,EAC7D,QAAQ,IAAI9B,EAAM,KAAK,MAAM4B,GAAa,CAAC,EAC3C,QAAQ,IACN5B,EAAM,KACJ,GAAG6B,KAAkBA,IAAmB,OAASA,IAAmB,MAAQ,OAAS,OACvF,CACF,EACA,QAAQ,KAAK,CAAC,CAChB,CAEA,eAAeK,EAAqB1B,EAAc2B,EAAqBC,EAAsB,CAC3F,GAAI,CACG/B,EAAWG,CAAI,IAClBmB,EAAO,MAAM,YAAYnB,mBAAsB,EAC/C,QAAQ,KAAK,CAAC,GAIhB,IAAM6B,GADY,MAAM/B,EAAG,SAASE,EAAM,MAAM,GAChB,WAAW2B,EAAaC,CAAY,EAEpE,MAAM9B,EAAG,UAAUE,EAAM6B,CAAa,CACxC,OAASb,EAAP,CACAC,EAAYD,CAAK,CACnB,CACF,CAEA,eAAeF,GAAeF,EAAa,CACzC,GAAI,MAAMkB,GAAuBlB,CAAG,EAAG,CACrC,GAAM,CAAE,QAAAmB,CAAQ,EAAI,MAAM9B,EAAQ,CAChC,KAAM,UACN,KAAM,UACN,QACE,0IACF,QAAS,EACX,CAAC,EAEI8B,IACHZ,EAAO,KAAK,yBAAyB,EACrC,QAAQ,KAAK,CAAC,GAGpB,CAEA,eAAeW,GAAuBlB,EAA+B,CACnE,GAAI,CACF,OAAAnB,EAAS,sCAAuC,CAAE,IAAAmB,CAAI,CAAC,EAEhD,CAAC,CADOnB,EAAS,yBAA0B,CAAE,IAAAmB,CAAI,CAAC,EAAE,SAAS,CAEtE,MAAE,CACA,MAAO,EACT,CACF,CAEA,eAAeG,GAAkBH,EAAaoB,EAAoB,CAChE,IAAMV,EAAUvB,EAAI,yBAAyB,EAAE,MAAM,EAErD,GAAI,CACF,IAAIkC,EAAS,MAAMC,EAAUtB,CAAG,EAE3BqB,IACHX,EAAQ,KAAK,EACbW,EAAS,MAAME,EAAgBvB,CAAG,EAClCU,EAAQ,MAAM,GAGhB,IAAMc,EAAepC,EAAK,KAAKK,EAAS,6BAA6B,EAErE,MAAMgC,GAAoBzB,EAAKU,CAAO,EACtC,MAAMgB,GAAe1B,EAAKqB,EAAQX,CAAO,EAEzCA,EAAQ,KAAO,qCACf,QAAWiB,KAAQhC,GACjB,MAAMiC,GAAiBD,EAAMH,EAAcxB,EAAKU,EAASU,CAAS,EAGpE,MAAMS,GAAiB7B,EAAKU,CAAO,EAEnCA,EAAQ,QAAQ,wCAAwC,CAC1D,OAASN,EAAP,CACAM,EAAQ,KAAK,uBAAuB,EACpCL,EAAYD,CAAK,EACjB,QAAQ,KAAK,CAAC,CAChB,CACF,CAEA,eAAeqB,GAAoBzB,EAAaU,EAAc,CAC5D,GAAI,CACFA,EAAQ,KAAO,6BACf,MAAM3B,EAAM,MAAO,CAAC,OAAQ,UAAW,GAAGW,EAAqB,EAAG,CAChE,IAAAM,EACA,MAAO,SACT,CAAC,EACDU,EAAQ,KAAO,qCACjB,OAASN,EAAP,CACAM,EAAQ,KAAK,gCAAgC,EAC7CL,EAAYD,CAAK,EACjB,QAAQ,KAAK,CAAC,CAChB,CACF,CAEA,IAAM0B,EAAuB,CAAC,GAAI,IAAK,GAAG,EAE1C,eAAeJ,GAAe1B,EAAaqB,EAAaX,EAAc,CACpE,GAAI,CACF,IAAMqB,EAAe3C,EAAK,KAAKY,EAAK,eAAe,EAC7CgC,EAAW/C,EAAW8C,CAAY,EACpC,KAAK,MAAM,MAAM7C,EAAG,SAAS6C,EAAc,MAAM,CAAC,EAClD,CAAC,EAECE,EAAgBZ,EAAO,QAAQ,WAAW,MAAM,GAAG,EAAE,CAAC,EACtDa,EAAUb,EAAO,QAAQ,IAAI,MAAM,GAAG,EAAE,CAAC,EAE/C,GAAIS,EAAqB,SAASG,CAAa,GAAKH,EAAqB,SAASI,CAAO,EACvF,OAGF,IAAMC,EAAgBH,EAAS,iBAAiB,OAAS,CAAC,EAE1D,GACEG,EAAc,GAAGF,KAAiB,IAAI,CAAC,IAAM,KAC7CE,EAAc,GAAGD,KAAW,IAAI,CAAC,IAAM,IACvC,CACAxB,EAAQ,QAAQ,iCAAiC,EACjD,OAGFA,EAAQ,KAAO,2BAEfsB,EAAS,gBAAkB,CACzB,GAAGA,EAAS,gBACZ,QAAS,IACT,MAAO,CACL,CAAC,GAAGC,KAAiB,EAAG,CAAC,GAAG,EAC5B,CAAC,GAAGC,KAAW,EAAG,CAAC,GAAG,EACtB,GAAGF,EAAS,iBAAiB,KAC/B,CACF,EAEA,MAAM9C,EAAG,UAAU6C,EAAc,KAAK,UAAUC,EAAU,KAAM,CAAC,CAAC,CACpE,OAAS5B,EAAP,CACAM,EAAQ,KAAK,gCAAgC,EAC7CL,EAAYD,CAAK,CACnB,CACF,CAEA,eAAewB,GACbD,EACAH,EACAY,EACA1B,EACA2B,EACA,CACA,IAAMC,EAAalD,EAAK,KAAKgD,EAAWT,CAAI,EAG5C,GAFAjB,EAAQ,KAAK,EAETzB,EAAWqD,CAAU,EAAG,CAC1B,GAAI,CAACD,EAAe,CAClB9B,EAAO,KACL,wBAAwB3B,EAAM,OAC5B+C,CACF,6CAA6C/C,EAAM,MAAM,aAAa,SACxE,EACA,OAGF,GAAM,CAAE,UAAAwC,CAAU,EAAI,MAAM/B,EAAQ,CAClC,KAAM,UACN,KAAM,YACN,QAAS,wBAAwBT,EAAM,OAAO+C,CAAI,kCAClD,QAAS,EACX,CAAC,EAED,GAAI,CAACP,EAAW,CACdb,EAAO,KAAK,SAAS,EACrB,QAIJG,EAAQ,MAAM,cAAciB,MAAS,EACrC,MAAMzC,EAAG,MAAME,EAAK,QAAQkD,CAAU,EAAG,CAAE,UAAW,EAAK,CAAC,EAC5D,MAAMpD,EAAG,SAASE,EAAK,KAAKoC,EAAcG,CAAI,EAAGW,CAAU,CAC7D,CAEA,eAAeT,GAAiB7B,EAAaU,EAAc,CACzD,GAAI,CACF,IAAM6B,EAAc,MAAMvD,GACxB,CAAC,8BAA+B,+BAA+B,EAC/D,CACE,IAAAgB,EACA,OAAQ,CAAC,iBAAiB,CAC5B,CACF,EAEA,GAAI,CAACuC,EAAY,OAAQ,CACvB7B,EAAQ,KAAK,sCAAsC,EACnD,OAGF,IAAM8B,EAAapD,EAAK,KAAKY,EAAKuC,EAAY,CAAC,CAAC,EAC1CE,EAAU,MAAMvD,EAAG,SAASsD,EAAY,MAAM,EAE/CC,EAAQ,SAAS,wBAAwB,IAC5C/B,EAAQ,KAAO,0BACf,MAAMxB,EAAG,UAAUsD,EAAY;AAAA,EAA4BC,GAAS,EACpE/B,EAAQ,QAAQ,WAAW6B,EAAY,CAAC,0BAA0B,EAEtE,OAASnC,EAAP,CACAM,EAAQ,KAAK,8BAA8B,EAC3CL,EAAYD,CAAK,CACnB,CACF,CCnWA,OAAS,WAAAsC,OAAe,YAExB,QAAQ,GAAG,SAAU,IAAM,QAAQ,KAAK,CAAC,CAAC,EAC1C,QAAQ,GAAG,UAAW,IAAM,QAAQ,KAAK,CAAC,CAAC,EAE3C,eAAeC,IAAO,CACpB,IAAMC,EAAU,IAAIF,GAAQ,EACzB,KAAK,6BAA6B,EAClC,YAAY,iDAAiD,EAEhEE,EAAQ,WAAWC,CAAG,EACtBD,EAAQ,WAAWE,EAAI,EAEvBF,EAAQ,MAAM,CAChB,CAEAD,GAAK","names":["createMatchPath","resolveImport","importPath","config","cosmiconfig","loadConfig","z","DEFAULT_COMPONENTS","DEFAULT_LIB","explorer","rawConfigSchema","configSchema","getConfig","cwd","config","getRawConfig","resolveConfigPaths","tsConfig","resolveImport","configResult","detect","getPackageManager","targetDir","packageManager","chalk","logger","args","handleError","error","logger","chalk","fs","ora","path","prompts","promptForConfig","cwd","highlight","text","options","DEFAULT_COMPONENTS","DEFAULT_LIB","config","rawConfigSchema","proceed","logger","spinner","targetPath","resolveConfigPaths","chalk","Command","execa","existsSync","fs","ora","path","prompts","fileURLToPath","z","COMPONENTS","getComponentDependencies","componentName","visited","component","COMPONENTS","comp","dependencies","dependency","childDependencies","INVALID_COMPONENT_ERROR","getAllComponentsToWrite","componentNames","uniqueComponents","allDependencies","dep","filePath","fileURLToPath","fileDir","path","addOptionsSchema","z","add","Command","components","opts","options","cwd","existsSync","logger","config","getConfig","promptForConfig","selectedComponents","prompts","COMPONENTS","entry","spinner","ora","componentsToWrite","getAllComponentsToWrite","err","INVALID_COMPONENT_ERROR","component","npmPackages","comp","writeFiles","packageManager","getPackageManager","uniqueNpmPackages","execa","error","handleError","paths","overwriteFlag","compPath","targetDir","fs","chalk","overwrite","readFromPath","content","fixImports","icon","rawfile","componentsAlias","libAlias","existsSync","fs","path","copyFolder","src","dest","options","entries","entry","srcPath","destPath","chalk","execSync","Command","execa","glob","existsSync","fs","ora","path","prompts","fileURLToPath","z","filePath","fileDir","REQUIRED_DEPENDENCIES","TEMPLATE_FILES","initOptionsSchema","init","opts","options","cwd","validateProjectDirectory","checkGitStatus","initializeProject","error","handleError","option","logger","projectName","packageManager","spinner","projectPath","filesToIgnore","copyFolder","replaceAllInJsonFile","searchValue","replaceValue","replacedValue","shouldPromptGitWarning","proceed","overwrite","config","getConfig","promptForConfig","templatesDir","installDependencies","updateTsConfig","file","copyTemplateFile","updateLayoutFile","NON_PATH_ALIAS_BASES","tsconfigPath","tsconfig","componentBase","libBase","tsconfigPaths","targetDir","overwriteFlag","targetPath","layoutFiles","layoutPath","content","Command","main","program","add","init"]}
1
+ {"version":3,"sources":["../src/utils/resolve-import.ts","../src/utils/get-config.ts","../src/utils/get-package-manager.ts","../src/utils/logger.ts","../src/utils/handle-error.ts","../src/utils/prompt-for-config.ts","../src/commands/add.ts","../src/items/components.ts","../src/items/index.ts","../src/utils/copy-folder.ts","../src/commands/init.ts","../src/index.ts"],"sourcesContent":["import { createMatchPath, type ConfigLoaderSuccessResult } from \"tsconfig-paths\"\n\nexport async function resolveImport(\n importPath: string,\n config: Pick<ConfigLoaderSuccessResult, \"absoluteBaseUrl\" | \"paths\">\n) {\n return createMatchPath(config.absoluteBaseUrl, config.paths)(\n importPath,\n undefined,\n () => true,\n [\".ts\", \".tsx\"]\n )\n}\n","import { resolveImport } from '@/src/utils/resolve-import';\nimport { cosmiconfig } from 'cosmiconfig';\nimport { loadConfig } from 'tsconfig-paths';\nimport { z } from 'zod';\n\nexport const DEFAULT_COMPONENTS = '~/components';\nexport const DEFAULT_LIB = '~/lib';\n\nconst explorer = cosmiconfig('components', {\n searchPlaces: ['components.json'],\n});\n\nexport const rawConfigSchema = z.object({\n aliases: z.object({\n components: z.string(),\n lib: z.string(),\n }),\n});\n\nexport type RawConfig = z.infer<typeof rawConfigSchema>;\n\nexport const configSchema = rawConfigSchema.extend({\n resolvedPaths: z.object({\n lib: z.string(),\n components: z.string(),\n }),\n});\n\nexport type Config = z.infer<typeof configSchema>;\n\nexport async function getConfig(cwd: string) {\n const config = await getRawConfig(cwd);\n\n if (!config) {\n return null;\n }\n\n return await resolveConfigPaths(cwd, config);\n}\n\nexport async function resolveConfigPaths(cwd: string, config: RawConfig) {\n // Read tsconfig.json.\n const tsConfig = await loadConfig(cwd);\n\n if (tsConfig.resultType === 'failed') {\n throw new Error(`Failed to load tsconfig.json. ${tsConfig.message ?? ''}`.trim());\n }\n\n return configSchema.parse({\n ...config,\n resolvedPaths: {\n lib: await resolveImport(config.aliases['lib'], tsConfig),\n components: await resolveImport(config.aliases['components'], tsConfig),\n },\n });\n}\n\nexport async function getRawConfig(cwd: string): Promise<RawConfig | null> {\n try {\n const configResult = await explorer.search(cwd);\n\n if (!configResult) {\n return null;\n }\n\n return rawConfigSchema.parse(configResult.config);\n } catch (error) {\n throw new Error(`Invalid configuration found in ${cwd}/components.json.`);\n }\n}\n","import { detect } from '@antfu/ni';\n\nexport async function getPackageManager(\n targetDir: string\n): Promise<'yarn' | 'pnpm' | 'bun' | 'npm'> {\n const packageManager = await detect({ programmatic: true, cwd: targetDir });\n\n if (packageManager === 'yarn@berry') return 'yarn';\n if (packageManager === 'pnpm@6') return 'pnpm';\n if (packageManager === 'bun') return 'bun';\n\n return packageManager ?? 'npm';\n}\n","import chalk from \"chalk\"\n\nexport const logger = {\n error(...args: unknown[]) {\n console.log(chalk.red(...args))\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(...args))\n },\n info(...args: unknown[]) {\n console.log(chalk.cyan(...args))\n },\n success(...args: unknown[]) {\n console.log(chalk.green(...args))\n },\n break() {\n console.log(\"\")\n },\n}\n","import { logger } from \"@/src/utils/logger\"\n\nexport function handleError(error: unknown) {\n if (typeof error === \"string\") {\n logger.error(error)\n process.exit(1)\n }\n\n if (error instanceof Error) {\n logger.error(error.message)\n process.exit(1)\n }\n\n logger.error(\"Something went wrong. Please try again.\")\n process.exit(1)\n}\n","import {\n DEFAULT_COMPONENTS,\n DEFAULT_LIB,\n rawConfigSchema,\n resolveConfigPaths,\n} from '@/src/utils/get-config';\nimport { logger } from '@/src/utils/logger';\nimport chalk from 'chalk';\nimport { promises as fs } from 'fs';\nimport ora from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\n\nexport async function promptForConfig(cwd: string) {\n const highlight = (text: string) => chalk.cyan(text);\n\n const options = await prompts([\n {\n type: 'text',\n name: 'components',\n message: `Configure the import alias for ${highlight('components')}:`,\n initial: DEFAULT_COMPONENTS,\n },\n {\n type: 'text',\n name: 'lib',\n message: `Configure the import alias for ${highlight('lib')}:`,\n initial: DEFAULT_LIB,\n },\n ]);\n\n const config = rawConfigSchema.parse({\n aliases: {\n lib: options.lib || DEFAULT_COMPONENTS,\n components: options.components || DEFAULT_LIB,\n },\n });\n\n const { proceed } = await prompts({\n type: 'confirm',\n name: 'proceed',\n message: `Write configuration to ${highlight('components.json')}. Proceed?`,\n initial: true,\n });\n\n if (proceed) {\n logger.info('');\n const spinner = ora(`Writing components.json...`).start();\n const targetPath = path.resolve(cwd, 'components.json');\n await fs.writeFile(targetPath, JSON.stringify(config, null, 2), 'utf8');\n spinner.succeed();\n }\n\n return await resolveConfigPaths(cwd, config);\n}\n","import { Config, getConfig } from '@/src/utils/get-config';\nimport { getPackageManager } from '@/src/utils/get-package-manager';\nimport { handleError } from '@/src/utils/handle-error';\nimport { logger } from '@/src/utils/logger';\nimport { promptForConfig } from '@/src/utils/prompt-for-config';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport { existsSync, promises as fs } from 'fs';\nimport ora, { Ora } from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\nimport { fileURLToPath } from 'url';\nimport { z } from 'zod';\nimport { Component, INVALID_COMPONENT_ERROR, getAllComponentsToWrite } from '../items';\nimport { COMPONENTS } from '../items/components';\n\nconst filePath = fileURLToPath(import.meta.url);\nconst fileDir = path.dirname(filePath);\n\nconst addOptionsSchema = z.object({\n components: z.array(z.string()).optional(),\n overwrite: z.boolean(),\n cwd: z.string(),\n path: z.string().optional(),\n});\n\nexport const add = new Command()\n .name('add')\n .description('add components to your project')\n .argument('[components...]', 'the components to add')\n .option('-o, --overwrite', 'overwrite existing files.', false)\n .option(\n '-c, --cwd <cwd>',\n 'the working directory. defaults to the current directory.',\n process.cwd()\n )\n .action(async (components, opts) => {\n try {\n const options = addOptionsSchema.parse({\n components,\n ...opts,\n });\n\n const cwd = path.resolve(options.cwd);\n\n if (!existsSync(cwd)) {\n logger.error(`The path ${cwd} does not exist. Please try again.`);\n process.exit(1);\n }\n\n let config = await getConfig(cwd);\n\n if (!config) {\n config = await promptForConfig(cwd);\n }\n\n let selectedComponents: Array<string> = options.components ?? [];\n if (!selectedComponents?.length) {\n const { components } = await prompts({\n type: 'multiselect',\n name: 'components',\n message: 'Which components would you like to add?',\n hint: 'Space to select. A to toggle all. Enter to submit.',\n instructions: false,\n choices: COMPONENTS.map((entry) => ({\n title: entry.name,\n value: entry.name,\n selected: false,\n })),\n });\n selectedComponents = components;\n }\n\n if (!selectedComponents?.length) {\n logger.warn('No components selected. Exiting.');\n process.exit(0);\n }\n\n const spinner = ora(`Installing components...`).start();\n\n let componentsToWrite: Array<Component> = [];\n try {\n componentsToWrite = getAllComponentsToWrite(selectedComponents);\n } catch (err) {\n if (err instanceof Error && err.message === INVALID_COMPONENT_ERROR) {\n logger.error(\n `Invalid component(s): ${selectedComponents\n .filter((component) => !COMPONENTS.find((entry) => entry.name === component))\n .join(', ')}`\n );\n process.exit(1);\n }\n logger.error(err);\n }\n\n const npmPackages: Array<string> = [];\n\n for (const comp of componentsToWrite) {\n spinner.text = `Installing ${comp.name}...`;\n\n await writeFiles(comp, comp.paths, config, spinner, options.overwrite);\n\n npmPackages.push(...comp.npmPackages);\n }\n\n const packageManager = await getPackageManager(cwd);\n\n const uniqueNpmPackages = Array.from(new Set(npmPackages));\n\n if (uniqueNpmPackages.length) {\n spinner.text = `Installing ${uniqueNpmPackages.join(', ')}...`;\n await execa(\n packageManager,\n [packageManager === 'npm' ? 'install' : 'add', ...uniqueNpmPackages],\n {\n cwd,\n }\n );\n }\n spinner.succeed(`Done.`);\n } catch (error) {\n handleError(error);\n }\n });\n\nasync function writeFiles(\n comp: Component,\n paths: Array<{ from: string; distFrom?: string; to: { folder: string; file: string } }>,\n config: Config,\n spinner: Ora,\n overwriteFlag: boolean\n) {\n for (const compPath of paths) {\n const targetDir = path.join(config.resolvedPaths.components, compPath.to.folder);\n if (!existsSync(targetDir)) {\n await fs.mkdir(targetDir, { recursive: true });\n }\n\n spinner.stop();\n\n if (existsSync(path.join(targetDir, compPath.to.file))) {\n const filePath = [compPath.to.folder, compPath.to.file].join('/');\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n filePath\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n continue;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(filePath)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped`);\n continue;\n }\n }\n\n spinner.start(`Installing ${comp.name}...`);\n const readFromPath = compPath.distFrom\n ? path.join(fileDir, '../__generated/components', compPath.distFrom)\n : path.join(fileDir, '../__generated/components', compPath.to.folder, compPath.to.file);\n try {\n const content = await fs.readFile(path.resolve(readFromPath), 'utf8');\n await fs.writeFile(\n path.join(targetDir, compPath.to.file),\n fixImports(content, config.aliases.components, config.aliases.lib)\n );\n } catch (error) {\n handleError(error);\n }\n }\n\n for (const icon of comp.icons ?? []) {\n const targetDir = path.resolve(config.resolvedPaths.lib, 'icons');\n if (!existsSync(targetDir)) {\n await fs.mkdir(targetDir, { recursive: true });\n try {\n await fs.writeFile(\n path.join(targetDir, `iconWithClassName.ts`),\n `import type { LucideIcon } from 'lucide-react-native';\\nimport { cssInterop } from 'nativewind';\\n\\nexport function iconWithClassName(icon: LucideIcon) {\\ncssInterop(icon, {\\n className: {\\n target: 'style',\\n nativeStyleToProp: {\\n color: true,\\n opacity: true,\\n },\\n },\\n});\\n}`\n );\n } catch (error) {\n handleError(error);\n }\n }\n\n if (existsSync(path.join(targetDir, `${icon}.tsx`))) {\n const filePath = path.join(targetDir, `${icon}.tsx`);\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n `${icon}.tsx`\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n continue;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(filePath)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped ${icon}.tsx`);\n continue;\n }\n }\n\n spinner.start(`Adding the ${icon} icon...`);\n\n try {\n await fs.writeFile(\n path.join(targetDir, `${icon}.tsx`),\n `import { ${icon} } from 'lucide-react-native';\\nimport { iconWithClassName } from './iconWithClassName';\\niconWithClassName(${icon});\\nexport { ${icon} };`\n );\n } catch (error) {\n handleError(error);\n }\n }\n}\n\nfunction fixImports(rawfile: string, componentsAlias: string, libAlias: string) {\n return rawfile\n .replace('./typography', `${componentsAlias}/ui/typography`)\n .replace('./text', `${componentsAlias}/ui/text`)\n .replaceAll('../../components', componentsAlias)\n .replaceAll('../../lib', libAlias);\n}\n","export const COMPONENTS = [\n {\n name: 'accordion',\n dependencies: ['text'],\n icons: ['ChevronDown'],\n npmPackages: ['@rn-primitives/accordion'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/accordion.tsx',\n to: {\n folder: 'ui',\n file: 'accordion.tsx',\n },\n },\n ],\n },\n {\n name: 'alert',\n dependencies: ['text'],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/alert.tsx',\n to: {\n folder: 'ui',\n file: 'alert.tsx',\n },\n },\n ],\n },\n {\n name: 'alert-dialog',\n dependencies: ['button', 'text'],\n icons: [],\n npmPackages: ['@rn-primitives/alert-dialog'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/alert-dialog.tsx',\n to: {\n folder: 'ui',\n file: 'alert-dialog.tsx',\n },\n },\n ],\n },\n {\n name: 'aspect-ratio',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/aspect-ratio'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/aspect-ratio.tsx',\n to: {\n folder: 'ui',\n file: 'aspect-ratio.tsx',\n },\n },\n ],\n },\n {\n name: 'avatar',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/avatar'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/avatar.tsx',\n to: {\n folder: 'ui',\n file: 'avatar.tsx',\n },\n },\n ],\n },\n {\n name: 'badge',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/badge.tsx',\n to: {\n folder: 'ui',\n file: 'badge.tsx',\n },\n },\n ],\n },\n {\n name: 'button',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/button.tsx',\n to: {\n folder: 'ui',\n file: 'button.tsx',\n },\n },\n ],\n },\n {\n name: 'card',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/card.tsx',\n to: {\n folder: 'ui',\n file: 'card.tsx',\n },\n },\n ],\n },\n {\n name: 'checkbox',\n dependencies: [],\n icons: ['Check'],\n npmPackages: ['@rn-primitives/checkbox'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/checkbox.tsx',\n to: {\n folder: 'ui',\n file: 'checkbox.tsx',\n },\n },\n ],\n },\n {\n name: 'collapsible',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/collapsible'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/collapsible.tsx',\n to: {\n folder: 'ui',\n file: 'collapsible.tsx',\n },\n },\n ],\n },\n {\n name: 'context-menu',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/context-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/context-menu.tsx',\n to: {\n folder: 'ui',\n file: 'context-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'dialog',\n dependencies: [],\n icons: ['X'],\n npmPackages: ['@rn-primitives/dialog'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/dialog.tsx',\n to: {\n folder: 'ui',\n file: 'dialog.tsx',\n },\n },\n ],\n },\n {\n name: 'dropdown-menu',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/dropdown-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/dropdown-menu.tsx',\n to: {\n folder: 'ui',\n file: 'dropdown-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'hover-card',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/hover-card'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/hover-card.tsx',\n to: {\n folder: 'ui',\n file: 'hover-card.tsx',\n },\n },\n ],\n },\n {\n name: 'input',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/input.tsx',\n to: {\n folder: 'ui',\n file: 'input.tsx',\n },\n },\n ],\n },\n {\n name: 'label',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/label'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/label.tsx',\n to: {\n folder: 'ui',\n file: 'label.tsx',\n },\n },\n ],\n },\n {\n name: 'menubar',\n dependencies: ['text'],\n icons: ['Check', 'ChevronDown', 'ChevronRight', 'ChevronUp'],\n npmPackages: ['@rn-primitives/menubar'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/menubar.tsx',\n to: {\n folder: 'ui',\n file: 'menubar.tsx',\n },\n },\n ],\n },\n {\n name: 'navigation-menu',\n dependencies: [],\n icons: ['ChevronDown'],\n npmPackages: ['@rn-primitives/navigation-menu'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/navigation-menu.tsx',\n to: {\n folder: 'ui',\n file: 'navigation-menu.tsx',\n },\n },\n ],\n },\n {\n name: 'popover',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/popover'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/popover.tsx',\n to: {\n folder: 'ui',\n file: 'popover.tsx',\n },\n },\n ],\n },\n {\n name: 'progress',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/progress'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/progress.tsx',\n to: {\n folder: 'ui',\n file: 'progress.tsx',\n },\n },\n ],\n },\n {\n name: 'radio-group',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/radio-group'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/radio-group.tsx',\n to: {\n folder: 'ui',\n file: 'radio-group.tsx',\n },\n },\n ],\n },\n {\n name: 'select',\n dependencies: [],\n icons: ['Check', 'ChevronDown', 'ChevronUp'],\n npmPackages: ['@rn-primitives/select'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/select.tsx',\n to: {\n folder: 'ui',\n file: 'select.tsx',\n },\n },\n ],\n },\n {\n name: 'separator',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/separator'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/separator.tsx',\n to: {\n folder: 'ui',\n file: 'separator.tsx',\n },\n },\n ],\n },\n {\n name: 'skeleton',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/skeleton.tsx',\n to: {\n folder: 'ui',\n file: 'skeleton.tsx',\n },\n },\n ],\n },\n {\n name: 'switch',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/switch'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/switch.tsx',\n to: {\n folder: 'ui',\n file: 'switch.tsx',\n },\n },\n ],\n },\n {\n name: 'table',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/table'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/table.tsx',\n to: {\n folder: 'ui',\n file: 'table.tsx',\n },\n },\n ],\n },\n {\n name: 'tabs',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/tabs'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/tabs.tsx',\n to: {\n folder: 'ui',\n file: 'tabs.tsx',\n },\n },\n ],\n },\n {\n name: 'text',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/text.tsx',\n to: { folder: 'ui', file: 'text.tsx' },\n },\n ],\n },\n {\n name: 'textarea',\n dependencies: [],\n icons: [],\n npmPackages: [],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/textarea.tsx',\n to: { folder: 'ui', file: 'textarea.tsx' },\n },\n ],\n },\n {\n name: 'toggle',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/toggle'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/toggle.tsx',\n to: { folder: 'ui', file: 'toggle.tsx' },\n },\n ],\n },\n {\n name: 'toggle-group',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/toggle-group'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/toggle-group.tsx',\n to: { folder: 'ui', file: 'toggle-group.tsx' },\n },\n ],\n },\n {\n name: 'tooltip',\n dependencies: ['text'],\n icons: [],\n npmPackages: ['@rn-primitives/tooltip'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/tooltip.tsx',\n to: { folder: 'ui', file: 'tooltip.tsx' },\n },\n ],\n },\n {\n name: 'typography',\n dependencies: [],\n icons: [],\n npmPackages: ['@rn-primitives/slot', '@rn-primitives/types'],\n paths: [\n {\n from: './node_modules/@rnr/reusables/src/components/ui/typography.tsx',\n to: { folder: 'ui', file: 'typography.tsx' },\n },\n ],\n },\n];\n","import { COMPONENTS } from './components';\n\nexport type Component = (typeof COMPONENTS)[number] & { icons?: string[] };\ntype ComponentName = (typeof COMPONENTS)[number]['name'];\n\nfunction getComponentDependencies(\n componentName: ComponentName,\n visited = new Set<ComponentName>()\n) {\n const component = COMPONENTS.find((comp) => comp.name === componentName);\n if (!component) return [];\n\n visited.add(componentName);\n\n let dependencies: ComponentName[] = component.dependencies.slice();\n\n component.dependencies.forEach((dependency) => {\n if (!visited.has(dependency)) {\n const childDependencies = getComponentDependencies(dependency, visited);\n dependencies = dependencies.concat(childDependencies);\n }\n });\n\n return dependencies;\n}\n\nexport const INVALID_COMPONENT_ERROR = 'invalid component';\n\nexport function getAllComponentsToWrite(componentNames: string[]): Component[] {\n const uniqueComponents = new Set<ComponentName>();\n\n if (\n componentNames.some((componentName) => !COMPONENTS.find((comp) => comp.name === componentName))\n ) {\n throw new Error(INVALID_COMPONENT_ERROR);\n }\n\n componentNames.forEach((componentName) => {\n const allDependencies = getComponentDependencies(componentName as ComponentName);\n allDependencies.unshift(componentName as never); // Add the component itself to the list\n allDependencies.forEach((dep) => {\n uniqueComponents.add(dep);\n });\n });\n\n return Array.from(uniqueComponents).map((dep) => {\n const comp = COMPONENTS.find((comp) => comp.name === dep);\n if (!comp) {\n throw new Error(INVALID_COMPONENT_ERROR);\n }\n return comp;\n });\n}\n","import { existsSync, promises as fs } from 'fs';\nimport path from 'path';\n\nexport async function copyFolder(\n src: string,\n dest: string,\n options: { ignore: string[]; renameTemplateFiles: boolean } = {\n ignore: [],\n renameTemplateFiles: false,\n }\n) {\n if (!existsSync(src)) {\n throw new Error(`Source folder does not exist: ${src}`);\n }\n\n if (!existsSync(dest)) {\n await fs.mkdir(dest, { recursive: true });\n }\n\n const entries = await fs.readdir(src, { withFileTypes: true });\n\n for (const entry of entries) {\n const srcPath = path.join(src, entry.name);\n const destPath = path.join(dest, entry.name);\n\n if (options.ignore.includes(entry.name)) {\n continue;\n }\n\n if (entry.isDirectory()) {\n await copyFolder(srcPath, destPath, options);\n } else if (entry.isFile()) {\n if (options.renameTemplateFiles && entry.name === 'gitignore-template') {\n await fs.copyFile(srcPath, path.join(dest, '.gitignore'));\n } else if (options.renameTemplateFiles && entry.name === 'npmrc-template') {\n await fs.copyFile(srcPath, path.join(dest, '.npmrc'));\n } else {\n await fs.copyFile(srcPath, destPath);\n }\n }\n }\n}\n","import { copyFolder } from '@/src/utils/copy-folder';\nimport { getConfig } from '@/src/utils/get-config';\nimport { handleError } from '@/src/utils/handle-error';\nimport { logger } from '@/src/utils/logger';\nimport { promptForConfig } from '@/src/utils/prompt-for-config';\nimport chalk from 'chalk';\nimport { execSync } from 'child_process';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport glob from 'fast-glob';\nimport { existsSync, promises as fs } from 'fs';\nimport ora, { Ora } from 'ora';\nimport path from 'path';\nimport prompts from 'prompts';\nimport { fileURLToPath } from 'url';\nimport { z } from 'zod';\n\nconst filePath = fileURLToPath(import.meta.url);\nconst fileDir = path.dirname(filePath);\n\nconst REQUIRED_DEPENDENCIES = [\n 'nativewind',\n 'expo-navigation-bar',\n 'tailwindcss',\n 'tailwindcss-animate',\n 'class-variance-authority',\n 'clsx',\n 'tailwind-merge',\n 'react-native-svg',\n 'react-native-reanimated',\n 'react-native-safe-area-context',\n 'lucide-react-native',\n '@rn-primitives/portal',\n] as const;\n\nconst TEMPLATE_FILES = [\n 'tailwind.config.js',\n 'nativewind-env.d.ts',\n 'global.css',\n 'babel.config.js',\n 'metro.config.js',\n 'lib/utils.ts',\n 'lib/useColorScheme.tsx',\n 'lib/constants.ts',\n 'lib/android-navigation-bar.ts',\n 'lib/icons/iconWithClassName.ts',\n] as const;\n\nconst initOptionsSchema = z.object({\n cwd: z.string(),\n overwrite: z.boolean(),\n});\n\nexport const init = new Command()\n .name('init')\n .description('Initialize the required configuration for your React Native project')\n .option(\n '-c, --cwd <cwd>',\n 'the working directory. defaults to the current directory.',\n process.cwd()\n )\n .option('-o, --overwrite', 'overwrite existing files', false)\n .action(async (opts) => {\n try {\n const options = initOptionsSchema.parse(opts);\n const cwd = path.resolve(options.cwd);\n\n await validateProjectDirectory(cwd);\n await checkGitStatus(cwd);\n await initializeProject(cwd, options.overwrite);\n } catch (error) {\n handleError(error);\n }\n });\n\nasync function validateProjectDirectory(cwd: string) {\n if (existsSync(cwd) && existsSync(path.join(cwd, 'package.json'))) {\n const { option } = await prompts({\n type: 'select',\n name: 'option',\n message:\n 'Package.json found. How would you like to proceed? (Selecting \"Cancel\" will exit the process)',\n choices: [\n { title: 'Automatically configure your existing project', value: 'existing-project' },\n { title: 'Init new project', value: 'new-project' },\n { title: 'Cancel', value: 'cancel' },\n ],\n initial: false,\n });\n\n if (option === 'cancel') {\n logger.info('Installation cancelled.');\n process.exit(0);\n }\n\n if (option === 'existing-project') {\n return;\n }\n }\n\n const { projectName } = await prompts({\n type: 'text',\n name: 'projectName',\n message: `What is the name of your project?`,\n initial: 'starter-base',\n });\n\n const { packageManager } = await prompts({\n type: 'select',\n name: 'packageManager',\n message: 'Which package manager would you like to use?',\n choices: [\n { title: 'npm', value: 'npm' },\n { title: 'yarn', value: 'yarn' },\n { title: 'pnpm', value: 'pnpm' },\n { title: 'bun', value: 'bun' },\n ],\n });\n\n const spinner = ora(`Initializing ${projectName}...`).start();\n\n const projectPath = path.join(cwd, projectName);\n if (!existsSync(projectPath)) {\n await fs.mkdir(projectPath, { recursive: true });\n }\n\n const filesToIgnore = [];\n\n if (packageManager !== 'pnpm') {\n filesToIgnore.push('npmrc-template');\n }\n\n await copyFolder(path.join(fileDir, '../__generated/starter-base'), projectPath, {\n ignore: filesToIgnore,\n renameTemplateFiles: true,\n });\n\n await Promise.all([\n replaceAllInJsonFile(path.join(projectPath, 'app.json'), 'starter-base', projectName),\n replaceAllInJsonFile(path.join(projectPath, 'package.json'), '@rnr/starter-base', projectName),\n ]);\n\n spinner.start('Installing dependencies...');\n await execa(packageManager, ['install'], {\n cwd: projectPath,\n });\n spinner.text = 'Verifying and updating any invalid package versions if needed...';\n await execa('npx', ['expo', 'install', '--fix'], {\n cwd: projectPath,\n });\n\n spinner.succeed('New project initialized successfully!');\n console.log(`\\nTo get started, run the following commands:\\n`);\n console.log(chalk.cyan(`cd ${projectName}`));\n console.log(\n chalk.cyan(\n `${packageManager} ${packageManager === 'npm' || packageManager === 'bun' ? 'run ' : ''}dev`\n )\n );\n process.exit(0);\n}\n\nasync function replaceAllInJsonFile(path: string, searchValue: string, replaceValue: string) {\n try {\n if (!existsSync(path)) {\n logger.error(`The path ${path} does not exist.`);\n process.exit(1);\n }\n\n const jsonValue = await fs.readFile(path, 'utf8');\n const replacedValue = jsonValue.replaceAll(searchValue, replaceValue);\n\n await fs.writeFile(path, replacedValue);\n } catch (error) {\n handleError(error);\n }\n}\n\nasync function checkGitStatus(cwd: string) {\n if (await shouldPromptGitWarning(cwd)) {\n const { proceed } = await prompts({\n type: 'confirm',\n name: 'proceed',\n message:\n 'The Git repository is dirty (uncommitted changes). It is recommended to commit your changes before proceeding. Do you want to continue?',\n initial: false,\n });\n\n if (!proceed) {\n logger.info('Installation cancelled.');\n process.exit(0);\n }\n }\n}\n\nasync function shouldPromptGitWarning(cwd: string): Promise<boolean> {\n try {\n execSync('git rev-parse --is-inside-work-tree', { cwd });\n const status = execSync('git status --porcelain', { cwd }).toString();\n return !!status;\n } catch (error) {\n return false;\n }\n}\n\nasync function initializeProject(cwd: string, overwrite: boolean) {\n const spinner = ora(`Initializing project...`).start();\n\n try {\n let config = await getConfig(cwd);\n\n if (!config) {\n spinner.stop();\n config = await promptForConfig(cwd);\n spinner.start();\n }\n\n const templatesDir = path.join(fileDir, '../__generated/starter-base');\n\n await installDependencies(cwd, spinner);\n await updateTsConfig(cwd, config, spinner);\n\n spinner.text = 'Adding config and utility files...';\n for (const file of TEMPLATE_FILES) {\n await copyTemplateFile(file, templatesDir, cwd, spinner, overwrite);\n }\n\n await updateLayoutFile(cwd, spinner);\n\n spinner.succeed('Initialization completed successfully!');\n } catch (error) {\n spinner.fail('Initialization failed');\n handleError(error);\n process.exit(1);\n }\n}\n\nasync function installDependencies(cwd: string, spinner: Ora) {\n try {\n spinner.text = 'Installing dependencies...';\n await execa('npx', ['expo', 'install', ...REQUIRED_DEPENDENCIES], {\n cwd,\n stdio: 'inherit',\n });\n spinner.text = 'Dependencies installed successfully';\n } catch (error) {\n spinner.fail('Failed to install dependencies');\n handleError(error);\n process.exit(1);\n }\n}\n\nconst NON_PATH_ALIAS_BASES = ['', '.', '/'];\n\nasync function updateTsConfig(cwd: string, config: any, spinner: Ora) {\n try {\n const tsconfigPath = path.join(cwd, 'tsconfig.json');\n const tsconfig = existsSync(tsconfigPath)\n ? JSON.parse(await fs.readFile(tsconfigPath, 'utf8'))\n : {};\n\n const componentBase = config.aliases.components.split('/')[0];\n const libBase = config.aliases.lib.split('/')[0];\n\n if (NON_PATH_ALIAS_BASES.includes(componentBase) || NON_PATH_ALIAS_BASES.includes(libBase)) {\n return;\n }\n\n const tsconfigPaths = tsconfig.compilerOptions?.paths ?? {};\n\n if (\n tsconfigPaths[`${componentBase}/*`]?.[0] === '*' &&\n tsconfigPaths[`${libBase}/*`]?.[0] === '*'\n ) {\n spinner.succeed('Path aliases already configured');\n return;\n }\n\n spinner.text = 'Updating path aliases...';\n\n tsconfig.compilerOptions = {\n ...tsconfig.compilerOptions,\n baseUrl: '.',\n paths: {\n [`${componentBase}/*`]: ['*'],\n [`${libBase}/*`]: ['*'],\n ...tsconfig.compilerOptions?.paths,\n },\n };\n\n await fs.writeFile(tsconfigPath, JSON.stringify(tsconfig, null, 2));\n } catch (error) {\n spinner.fail('Failed to update tsconfig.json');\n handleError(error);\n }\n}\n\nasync function copyTemplateFile(\n file: string,\n templatesDir: string,\n targetDir: string,\n spinner: Ora,\n overwriteFlag: boolean\n) {\n const targetPath = path.join(targetDir, file);\n spinner.stop();\n\n if (existsSync(targetPath)) {\n if (!overwriteFlag) {\n logger.info(\n `File already exists: ${chalk.bgCyan(\n file\n )} was skipped. To overwrite, run with the ${chalk.green('--overwrite')} flag.`\n );\n return;\n }\n\n const { overwrite } = await prompts({\n type: 'confirm',\n name: 'overwrite',\n message: `File already exists: ${chalk.yellow(file)}. Would you like to overwrite?`,\n initial: false,\n });\n\n if (!overwrite) {\n logger.info(`Skipped`);\n return;\n }\n }\n\n spinner.start(`Installing ${file}...`);\n await fs.mkdir(path.dirname(targetPath), { recursive: true });\n await fs.copyFile(path.join(templatesDir, file), targetPath);\n}\n\nasync function updateLayoutFile(cwd: string, spinner: Ora) {\n try {\n const layoutFiles = await glob(\n ['app/_layout.{ts,tsx,js,jsx}', '(app)/_layout.{ts,tsx,js,jsx}'],\n {\n cwd,\n ignore: ['node_modules/**'],\n }\n );\n\n if (!layoutFiles.length) {\n spinner.warn('Could not find the root _layout file');\n return;\n }\n\n const layoutPath = path.join(cwd, layoutFiles[0]);\n const content = await fs.readFile(layoutPath, 'utf8');\n\n if (!content.includes('import \"../global.css\"')) {\n spinner.text = 'Updating layout file...';\n await fs.writeFile(layoutPath, `import \"../global.css\";\\n${content}`);\n spinner.succeed(`Updated ${layoutFiles[0]} with global CSS import`);\n }\n } catch (error) {\n spinner.fail('Failed to update layout file');\n handleError(error);\n }\n}\n","#!/usr/bin/env node\nimport { add } from '@/src/commands/add';\nimport { init } from '@/src/commands/init';\n\nimport { Command } from 'commander';\n\nprocess.on('SIGINT', () => process.exit(0));\nprocess.on('SIGTERM', () => process.exit(0));\n\nasync function main() {\n const program = new Command()\n .name('@react-native-reusables/cli')\n .description('add components and dependencies to your project');\n\n program.addCommand(add);\n program.addCommand(init);\n\n program.parse();\n}\n\nmain();\n"],"mappings":"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","names":["createMatchPath","resolveImport","importPath","config","cosmiconfig","loadConfig","z","DEFAULT_COMPONENTS","DEFAULT_LIB","explorer","rawConfigSchema","configSchema","getConfig","cwd","config","getRawConfig","resolveConfigPaths","tsConfig","resolveImport","configResult","detect","getPackageManager","targetDir","packageManager","chalk","logger","args","handleError","error","logger","chalk","fs","ora","path","prompts","promptForConfig","cwd","highlight","text","options","DEFAULT_COMPONENTS","DEFAULT_LIB","config","rawConfigSchema","proceed","logger","spinner","targetPath","resolveConfigPaths","chalk","Command","execa","existsSync","fs","ora","path","prompts","fileURLToPath","z","COMPONENTS","getComponentDependencies","componentName","visited","component","COMPONENTS","comp","dependencies","dependency","childDependencies","INVALID_COMPONENT_ERROR","getAllComponentsToWrite","componentNames","uniqueComponents","allDependencies","dep","filePath","fileURLToPath","fileDir","path","addOptionsSchema","z","add","Command","components","opts","options","cwd","existsSync","logger","config","getConfig","promptForConfig","selectedComponents","prompts","COMPONENTS","entry","spinner","ora","componentsToWrite","getAllComponentsToWrite","err","INVALID_COMPONENT_ERROR","component","npmPackages","comp","writeFiles","packageManager","getPackageManager","uniqueNpmPackages","execa","error","handleError","paths","overwriteFlag","compPath","targetDir","fs","chalk","overwrite","readFromPath","content","fixImports","icon","rawfile","componentsAlias","libAlias","existsSync","fs","path","copyFolder","src","dest","options","entries","entry","srcPath","destPath","chalk","execSync","Command","execa","glob","existsSync","fs","ora","path","prompts","fileURLToPath","z","filePath","fileDir","REQUIRED_DEPENDENCIES","TEMPLATE_FILES","initOptionsSchema","init","opts","options","cwd","validateProjectDirectory","checkGitStatus","initializeProject","error","handleError","option","logger","projectName","packageManager","spinner","projectPath","filesToIgnore","copyFolder","replaceAllInJsonFile","searchValue","replaceValue","replacedValue","shouldPromptGitWarning","proceed","overwrite","config","getConfig","promptForConfig","templatesDir","installDependencies","updateTsConfig","file","copyTemplateFile","updateLayoutFile","NON_PATH_ALIAS_BASES","tsconfigPath","tsconfig","componentBase","libBase","tsconfigPaths","targetDir","overwriteFlag","targetPath","layoutFiles","layoutPath","content","Command","main","program","add","init"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@react-native-reusables/cli",
3
- "version": "0.3.4",
3
+ "version": "0.3.5",
4
4
  "description": "Add react-native-reusables to your project.",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -65,8 +65,8 @@
65
65
  "tsx": "^4.7.1",
66
66
  "type-fest": "^3.8.0",
67
67
  "typescript": "^5.3.3",
68
- "@rnr/starter-base": "1.0.0",
69
- "@rnr/reusables": "0.0.0"
68
+ "@rnr/reusables": "0.0.0",
69
+ "@rnr/starter-base": "1.0.0"
70
70
  },
71
71
  "scripts": {
72
72
  "gen": "rm -rf __generated && tsx scripts/generate-source-files.ts",