@solvro/config 2.0.2 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/dist/{adonis-MGLA5SOL.js → adonis-GN4AQKAU.js} +4 -8
  2. package/dist/{adonis-MGLA5SOL.js.map → adonis-GN4AQKAU.js.map} +1 -1
  3. package/dist/{chunk-VSUL3MI5.js → chunk-LNSDT6IT.js} +2 -6
  4. package/dist/{chunk-VSUL3MI5.js.map → chunk-LNSDT6IT.js.map} +1 -1
  5. package/dist/{chunk-AQ5RXFKK.js → chunk-SUGOLX7X.js} +2 -6
  6. package/dist/{chunk-AQ5RXFKK.js.map → chunk-SUGOLX7X.js.map} +1 -1
  7. package/dist/{chunk-HM3MY7J3.js → chunk-VMUJRX4H.js} +1 -6
  8. package/dist/{chunk-HM3MY7J3.js.map → chunk-VMUJRX4H.js.map} +1 -1
  9. package/dist/{chunk-VD4FWSAD.js → chunk-VXVVMPZI.js} +2 -7
  10. package/dist/{chunk-VD4FWSAD.js.map → chunk-VXVVMPZI.js.map} +1 -1
  11. package/dist/cli/index.js +31 -38
  12. package/dist/cli/index.js.map +1 -1
  13. package/dist/commitlint/index.js +0 -5
  14. package/dist/commitlint/index.js.map +1 -1
  15. package/dist/eslint/index.js +11 -153
  16. package/dist/eslint/index.js.map +1 -1
  17. package/dist/{nestjs-33SQ4ZD2.js → nestjs-SVXAEFXN.js} +5 -9
  18. package/dist/{nestjs-33SQ4ZD2.js.map → nestjs-SVXAEFXN.js.map} +1 -1
  19. package/dist/{node-RC2VAG45.js → node-LOZFNKBL.js} +5 -9
  20. package/dist/{node-RC2VAG45.js.map → node-LOZFNKBL.js.map} +1 -1
  21. package/dist/prettier/index.js +0 -5
  22. package/dist/prettier/index.js.map +1 -1
  23. package/dist/react-CM27K2YV.js +167 -0
  24. package/dist/react-CM27K2YV.js.map +1 -0
  25. package/package.json +6 -5
  26. package/dist/chunk-J5OUMHDO.js +0 -44
  27. package/dist/chunk-J5OUMHDO.js.map +0 -1
  28. package/dist/react-PWJWWBLW.js +0 -2205
  29. package/dist/react-PWJWWBLW.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/cli/index.ts","../../package.json","../../src/utils/is-git-clean.ts","../../src/utils/package-json.ts","../../src/utils/$$.ts","../../src/utils/git-root.ts","../../src/utils/run-if-interactive.ts","../../src/utils/polish-confirm.ts","../../src/cli/install-commitlint.ts","../../src/cli/install-husky.ts","../../src/cli/templates/commitlint.ts","../../src/cli/install-eslint.ts","../../src/cli/install-ga.ts","../../src/cli/templates/adonis-ci.ts","../../src/cli/templates/commit-lint-ci.ts","../../src/cli/templates/adonis-ci-migrations.ts","../../src/cli/templates/dependabot.ts","../../src/cli/templates/nestjs-ci.ts","../../src/cli/templates/react-ci.ts","../../src/cli/install-lint-staged.ts","../../src/cli/install-prettier.ts"],"sourcesContent":["import * as p from \"@clack/prompts\";\nimport { Command } from \"commander\";\nimport c from \"picocolors\";\n\nimport packageJsonData from \"../../package.json\";\nimport { isGitClean } from \"../utils/is-git-clean\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\nimport { installCommitLint } from \"./install-commitlint\";\nimport { installEslint } from \"./install-eslint\";\nimport { installGithubActions } from \"./install-ga\";\nimport { installLintStaged } from \"./install-lint-staged\";\nimport { installPrettier } from \"./install-prettier\";\n\n// Types\ninterface CliOptions {\n force?: boolean;\n eslint?: boolean;\n prettier?: boolean;\n ghAction?: boolean;\n commitlint?: boolean;\n all?: boolean;\n}\n\n// CLI setup\nconst program = new Command();\nprogram\n .name(\"@solvro/config\")\n .description(\"Solvro's engineering style guide setup\")\n .version(packageJsonData.version)\n .option(\"-f, --force\", \"Skip git clean check\", false)\n .option(\"--eslint\", \"Install ESLint configuration\", false)\n .option(\"--prettier\", \"Install Prettier configuration\", false)\n .option(\"--gh-action\", \"Install GitHub Actions\", false)\n .option(\"--commitlint\", \"Install Commitlint configuration\", false)\n .option(\"-a, --all\", \"Install all tools\", false);\n\nprogram.parse();\nconst options: CliOptions = program.opts();\n\n// Check if running in non-interactive mode (any CLI flags provided)\nconst isNonInteractive = process.argv.length > 2;\n\nasync function main() {\n if (!isNonInteractive) {\n p.intro(c.bold(c.bgBlue(\" @solvro/config \")));\n }\n\n // Git clean check\n if (options.force !== true && !isGitClean()) {\n if (isNonInteractive) {\n console.error(\n \"Git repository has uncommitted changes. Use --force to bypass this check.\",\n );\n process.exit(1);\n }\n\n const isConfirmed = await polishConfirm({\n message: `Masz niezapisane zmiany w Git. Czy chcesz kontynuować?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zapisz zmiany w Git i spróbuj ponownie.\");\n process.exit(1);\n }\n }\n\n const packageJson = new PackageJson();\n\n // Determine project type automatically\n const projectType = await packageJson.getProjectType();\n\n // Project type confirmation (interactive mode only)\n if (!isNonInteractive) {\n if (projectType === \"adonis\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał Adonisa. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zgłoś błąd na GitHubie :(, a my spróbujemy pomóc.\");\n process.exit(1);\n }\n }\n\n if (projectType === \"react\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał Reacta. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed)) {\n p.cancel(\"😡\");\n process.exit(1);\n }\n\n if (!isConfirmed) {\n p.cancel(\"Zgłoś błąd na GitHubie :(, a my spróbujemy pomóc.\");\n process.exit(1);\n }\n }\n\n if (projectType === \"nestjs\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał NestJsa. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed)) {\n p.cancel(\"😡\");\n process.exit(1);\n }\n }\n\n if (projectType === \"node\") {\n p.cancel(\n \"Nie znaleziono ani Adonisa, Reacta, ani NestJsa. Musisz ręcznie konfigurować projekt.\",\n );\n process.exit(1);\n }\n }\n if (projectType === \"adonis\" || projectType === \"react\") {\n if (isNonInteractive) {\n await packageJson.ensureESM();\n } else {\n if (!(await packageJson.isESM())) {\n const isConfirmed = await polishConfirm({\n message: `Twój projekt nie używa ESM (brak type: \"module\" w package.json). Czy chcesz to dodać? (Wymagane by kontynuować)`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zmień projekt na ESM i spróbuj ponownie.\");\n process.exit(1);\n }\n\n await packageJson.ensureESM();\n }\n }\n }\n\n // Determine which tools to install\n let toolsToInstall: string[] = [];\n\n if (options.all === true) {\n toolsToInstall = [\"eslint\", \"prettier\", \"gh-action\", \"commitlint\"];\n } else if (isNonInteractive) {\n // In non-interactive mode, only install explicitly requested tools\n if (options.eslint === true) {\n toolsToInstall.push(\"eslint\");\n }\n if (options.prettier === true) {\n toolsToInstall.push(\"prettier\");\n }\n if (options.ghAction === true) {\n toolsToInstall.push(\"gh-action\");\n }\n if (options.commitlint === true) {\n toolsToInstall.push(\"commitlint\");\n }\n\n if (toolsToInstall.length === 0) {\n console.error(\n \"No tools specified. Use --eslint, --prettier, --gh-action, --commitlint, or --all\",\n );\n process.exit(1);\n }\n } else {\n // Interactive mode\n const additionalTools = await p.multiselect({\n message: `Które rzeczy Cię interesują? ${c.gray(\"zaznacz spacją, potwierdź enterem\")}`,\n initialValues: [\"eslint\", \"prettier\", \"gh-action\", \"commitlint\"],\n options: [\n {\n value: \"eslint\",\n label: c.bold(c.blueBright(\"ESLint\")),\n hint: \"sprawdzanie jakości kodu\",\n },\n {\n value: \"prettier\",\n label: c.bold(c.yellowBright(\"Prettier\")),\n hint: \"formatowanie\",\n },\n {\n value: \"gh-action\",\n label: c.bold(\"GitHub Actions\"),\n hint: \"automatyczne testy na Githubie\",\n },\n {\n value: \"commitlint\",\n label: c.bold(\"Commitlint\"),\n hint: \"walidacja treści commitów\",\n },\n ],\n required: false,\n });\n\n if (p.isCancel(additionalTools) || additionalTools.length === 0) {\n p.cancel(\"Nie wybrano żadnych narzędzi.\");\n process.exit(1);\n }\n\n toolsToInstall = additionalTools;\n }\n\n // Install the base package\n await packageJson.install(\"@solvro/config\", {\n dev: true,\n alwaysUpdate: !isNonInteractive,\n });\n\n // Install selected tools\n if (toolsToInstall.includes(\"eslint\")) {\n await installEslint(isNonInteractive);\n }\n\n if (toolsToInstall.includes(\"prettier\")) {\n await installPrettier(isNonInteractive);\n await installLintStaged();\n }\n\n if (toolsToInstall.includes(\"commitlint\")) {\n await installCommitLint();\n }\n\n if (toolsToInstall.includes(\"gh-action\")) {\n await installGithubActions();\n }\n\n await packageJson.clearInstall();\n\n if (isNonInteractive) {\n console.log(\"✅ Configuration completed successfully!\");\n } else {\n p.outro(\"✅ Configuration completed successfully!\");\n }\n}\n\n// Run the main function\ntry {\n await main();\n} catch (error: unknown) {\n console.error(\"An error occurred:\", error);\n process.exit(1);\n}\n","{\n \"name\": \"@solvro/config\",\n \"version\": \"2.0.1\",\n \"description\": \"Solvro's engineering style guide\",\n \"keywords\": [\n \"eslint\",\n \"prettier\",\n \"solvro\"\n ],\n \"homepage\": \"https://github.com/Solvro/lib-web-solvro-config#readme\",\n \"bugs\": {\n \"url\": \"https://github.com/Solvro/lib-web-solvro-config/issues\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/Solvro/lib-web-solvro-config.git\"\n },\n \"license\": \"MPL-2.0\",\n \"type\": \"module\",\n \"exports\": {\n \"./eslint\": {\n \"types\": \"./dist/eslint/index.d.ts\",\n \"import\": \"./dist/eslint/index.js\",\n \"require\": \"./dist/eslint/index.cjs\"\n },\n \"./prettier\": {\n \"types\": \"./dist/prettier/index.d.ts\",\n \"import\": \"./dist/prettier/index.js\",\n \"require\": \"./dist/prettier/index.cjs\"\n },\n \"./commitlint\": {\n \"types\": \"./dist/commitlint/index.d.ts\",\n \"import\": \"./dist/commitlint/index.js\",\n \"require\": \"./dist/commitlint/index.cjs\"\n }\n },\n \"bin\": \"./bin/index.js\",\n \"files\": [\n \"dist\"\n ],\n \"scripts\": {\n \"build\": \"tsup\",\n \"build:watch\": \"tsup --watch\",\n \"cli\": \"tsx ./src/cli/index.ts\",\n \"dev\": \"npx @eslint/config-inspector\",\n \"format\": \"prettier --check .\",\n \"knip\": \"knip\",\n \"lint\": \"eslint .\",\n \"prepare\": \"husky || true\",\n \"prepublish\": \"npm run build\",\n \"release\": \"semantic-release\",\n \"test\": \"vitest run\",\n \"test:ui\": \"vitest --ui\",\n \"test:watch\": \"vitest\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"lint-staged\": {\n \"*\": \"prettier -w --ignore-unknown\"\n },\n \"prettier\": \"./dist/prettier/index.js\",\n \"dependencies\": {\n \"@adonisjs/eslint-config\": \"^2.1.0\",\n \"@clack/prompts\": \"^0.11.0\",\n \"@commitlint/config-conventional\": \"^19.8.1\",\n \"@darraghor/eslint-plugin-nestjs-typed\": \"^6.7.0\",\n \"@eslint-community/eslint-plugin-eslint-comments\": \"^4.5.0\",\n \"@eslint/js\": \"^9.30.1\",\n \"@tanstack/eslint-plugin-query\": \"^5.81.2\",\n \"@trivago/prettier-plugin-sort-imports\": \"^5.2.2\",\n \"@typescript-eslint/eslint-plugin\": \"^8.35.1\",\n \"commander\": \"^14.0.0\",\n \"eslint-config-prettier\": \"^10.1.5\",\n \"eslint-plugin-antfu\": \"^3.1.1\",\n \"eslint-plugin-import\": \"^2.32.0\",\n \"eslint-plugin-jsdoc\": \"^51.3.3\",\n \"eslint-plugin-jsx-a11y\": \"^6.10.2\",\n \"eslint-plugin-n\": \"^17.21.0\",\n \"eslint-plugin-react\": \"^7.37.5\",\n \"eslint-plugin-react-hooks\": \"^5.2.0\",\n \"eslint-plugin-react-refresh\": \"^0.4.16\",\n \"eslint-plugin-unicorn\": \"^59.0.1\",\n \"eslint-plugin-unused-imports\": \"^4.1.4\",\n \"execa\": \"^9.6.0\",\n \"find-up-simple\": \"^1.0.1\",\n \"globals\": \"^16.3.0\",\n \"is-interactive\": \"^2.0.0\",\n \"local-pkg\": \"^1.1.1\",\n \"picocolors\": \"^1.1.1\",\n \"prettier-plugin-packagejson\": \"^2.5.18\",\n \"prettier-plugin-tailwindcss\": \"^0.6.13\",\n \"semver\": \"^7.7.2\",\n \"typescript-eslint\": \"^8.35.1\"\n },\n \"devDependencies\": {\n \"@commitlint/cli\": \"^19.8.1\",\n \"@eslint/config-inspector\": \"^1.1.0\",\n \"@next/eslint-plugin-next\": \"^15.3.5\",\n \"@semantic-release/git\": \"^10.0.1\",\n \"@types/node\": \"^24.0.10\",\n \"@types/semver\": \"^7.7.0\",\n \"@vitest/coverage-v8\": \"^3.2.4\",\n \"@vitest/ui\": \"^3.2.4\",\n \"eslint\": \"^9.30.1\",\n \"eslint-config-flat-gitignore\": \"^2.1.0\",\n \"eslint-plugin-react-you-might-not-need-an-effect\": \"^0.4.1\",\n \"husky\": \"^9.1.7\",\n \"jiti\": \"^2.4.2\",\n \"knip\": \"^5.61.3\",\n \"lint-staged\": \"^16.1.2\",\n \"prettier\": \"^3.6.2\",\n \"semantic-release\": \"^24.2.6\",\n \"tsup\": \"^8.5.0\",\n \"tsx\": \"^4.20.3\",\n \"typescript\": \"^5.8.3\",\n \"vitest\": \"^3.2.4\"\n },\n \"peerDependencies\": {\n \"@next/eslint-plugin-next\": \">=12.3.0 <16.0.0-0\"\n },\n \"packageManager\": \"npm@11.4.2\",\n \"engines\": {\n \"node\": \"^20.19.0 || >=22.12.0\"\n },\n \"volta\": {\n \"node\": \"22.17.0\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n }\n}\n","import { execSync } from \"node:child_process\";\n\nexport function isGitClean(): boolean {\n try {\n execSync(\"git diff-index --quiet HEAD --\");\n return true;\n } catch {\n return false;\n }\n}\n","import * as p from \"@clack/prompts\";\nimport { getPackageInfo, isPackageListed, loadPackageJSON } from \"local-pkg\";\nimport assert from \"node:assert\";\nimport { writeFile } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport semver from \"semver\";\n\nimport { $$ } from \"./$$\";\nimport { projectRoot } from \"./git-root\";\nimport { runIfInteractive } from \"./run-if-interactive\";\n\nexport class PackageJson {\n public json: Awaited<ReturnType<typeof loadPackageJSON>> = null;\n\n async load() {\n const json = await loadPackageJSON(projectRoot());\n\n if (json === null) {\n p.cancel(\n \"Nie znaleziono package.json. Upewnij się, że jesteś w katalogu projektu.\",\n );\n process.exit(1);\n }\n\n this.json = json;\n }\n\n hasPackage(package_: string) {\n return isPackageListed(package_);\n }\n\n async doesSatisfies(package_: string, version: string) {\n await this.load();\n\n assert.ok(this.json !== null);\n\n const packageInfo = await getPackageInfo(package_);\n\n if (packageInfo?.version === undefined) {\n return false;\n }\n\n return semver.satisfies(packageInfo.version, version);\n }\n\n async isESM() {\n await this.load();\n\n assert.ok(this.json !== null);\n\n return this.json.type === \"module\";\n }\n\n async ensureESM() {\n if (await this.isESM()) {\n return;\n }\n\n assert.ok(this.json !== null);\n\n this.json.type = \"module\";\n\n await this.save();\n }\n\n async getProjectType() {\n const isAdonis = await isPackageListed(\"@adonisjs/core\");\n const isReact = await isPackageListed(\"react\");\n const isNestJs = await isPackageListed(\"@nestjs/core\");\n if (isReact && isAdonis) {\n throw new Error(\n \"You can't use both Adonis and React in the same project\",\n );\n }\n\n if (isNestJs) {\n return \"nestjs\";\n }\n\n if (isAdonis) {\n return \"adonis\";\n }\n\n if (isReact) {\n return \"react\";\n }\n\n return \"node\";\n }\n\n async save() {\n await writeFile(\n path.join(projectRoot(), \"package.json\"),\n JSON.stringify(this.json, null, 2),\n );\n }\n\n async addScriptIfNotExists(name: string, script: string) {\n await this.load();\n\n assert.ok(this.json !== null);\n\n if (this.json.scripts?.[name] !== undefined) {\n return;\n }\n\n this.json.scripts = this.json.scripts ?? {};\n this.json.scripts[name] = script;\n\n await this.save();\n }\n\n async install(\n package_: string,\n options?: { minVersion?: string; dev?: boolean; alwaysUpdate?: boolean },\n ) {\n const isInstalled = await this.hasPackage(package_);\n\n if (!isInstalled) {\n const spinner = p.spinner();\n runIfInteractive(() => {\n spinner.start(`Instalowanie ${package_}`);\n });\n\n await $$`npm i ${options?.dev === true ? \"-D\" : \"\"} ${package_}@latest`;\n runIfInteractive(() => {\n spinner.stop(`${package_} zainstalowany 😍`);\n });\n\n await this.load();\n\n return;\n }\n\n const info = await getPackageInfo(package_);\n\n if (\n (info?.version !== undefined &&\n options?.minVersion !== undefined &&\n !semver.satisfies(info.version, options.minVersion)) ||\n options?.alwaysUpdate === true\n ) {\n const spinner = p.spinner();\n runIfInteractive(() => {\n spinner.start(`Aktualizowanie ${package_}`);\n });\n await $$`npm i ${options.dev === true ? \"-D\" : \"\"} ${package_}@latest`;\n runIfInteractive(() => {\n spinner.stop(`${package_} zaktualizowany 😍`);\n });\n\n await this.load();\n }\n }\n\n async clearInstall() {\n await $$`npm ci`;\n }\n}\n","import type { ExecaScriptMethod } from \"execa\";\n\nimport { projectRoot } from \"./git-root\";\n\nlet cachedExeca: ExecaScriptMethod | null = null;\n\nexport const $$ = (async (...arguments_: Parameters<ExecaScriptMethod>) => {\n if (cachedExeca === null) {\n const { $ } = await import(\"execa\");\n cachedExeca = $({\n cwd: projectRoot(),\n });\n }\n return cachedExeca(...arguments_);\n}) as ExecaScriptMethod;\n","import { findUpSync } from \"find-up-simple\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\n\nexport const projectRoot = () => {\n const packageJsonPath = findUpSync(\"package.json\");\n\n if (packageJsonPath !== undefined) {\n return path.dirname(packageJsonPath);\n }\n\n return process.cwd();\n};\n\nexport const gitRoot = () => {\n try {\n const rootDirectory = execSync(\"git rev-parse --show-toplevel\", {\n cwd: projectRoot(),\n });\n return rootDirectory.toString().trim();\n } catch {\n return projectRoot();\n }\n};\n","import isInteractive from \"is-interactive\";\n\nexport const runIfInteractive = <T>(function_: () => T): T | undefined => {\n if (isInteractive()) {\n return function_();\n }\n\n return undefined;\n};\n","import * as p from \"@clack/prompts\";\nimport isInteractive from \"is-interactive\";\n\nexport const polishConfirm = async (props: p.ConfirmOptions) => {\n if (!isInteractive()) {\n return true;\n }\n\n return p.confirm({\n active: \"Tak\",\n inactive: \"Nie\",\n ...props,\n });\n};\n","import { writeFile } from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { installHusky } from \"./install-husky\";\nimport { commitlint } from \"./templates/commitlint\";\n\nconst root = projectRoot();\n\nconst packageJson = new PackageJson();\n\nexport const installCommitLint = async () => {\n await installHusky();\n\n await packageJson.install(\"@commitlint/cli\", { dev: true });\n\n await writeFile(\n path.join(root, \".husky/commit-msg\"),\n 'npx commitlint --edit \"$1\"\\n',\n );\n\n await writeFile(path.join(root, \".commitlintrc.js\"), commitlint());\n};\n","import assert from \"node:assert\";\n\nimport { $$ } from \"../utils/$$\";\nimport { PackageJson } from \"../utils/package-json\";\n\nconst packageJson = new PackageJson();\n\nexport const installHusky = async () => {\n if (!(await packageJson.hasPackage(\"husky\"))) {\n await packageJson.install(\"husky\", { dev: true });\n await $$`npx husky init`;\n }\n\n await packageJson.load();\n\n assert.ok(packageJson.json !== null);\n\n packageJson.json.scripts = packageJson.json.scripts ?? {};\n packageJson.json.scripts.prepare = `husky || true`;\n\n await packageJson.save();\n};\n","export const commitlint = () => `export default {\n extends: [\"@solvro/config/commitlint\"],\n};\n`;\n","import * as p from \"@clack/prompts\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\n\nconst eslintConfigNames = [\n \".eslintrc.js\",\n \".eslintrc.cjs\",\n \".eslintrc.yaml\",\n \".eslintrc.yml\",\n \".eslintrc.json\",\n \".eslintrc\",\n \"eslint.config.js\",\n \"eslint.config.mjs\",\n \"eslint.config.cjs\",\n \"eslint.config.ts\",\n \"eslint.config.mts\",\n \"eslint.config.cts\",\n];\n\nconst packageJson = new PackageJson();\n\nexport const installEslint = async (isNonInteractive = false) => {\n const root = projectRoot();\n\n await packageJson.load();\n\n await packageJson.install(\"eslint\", { dev: true, minVersion: \">=9\" });\n\n const type = await packageJson.getProjectType();\n\n if (type === \"react\" && (await packageJson.hasPackage(\"next\"))) {\n const is15 = await packageJson.doesSatisfies(\"next\", \">=15\");\n\n if (!is15) {\n p.cancel(\n \"Next.js musi być w conajmniej wersji 15. Zaktualizuj Next.js i spróbuj ponownie.\\nWięcej informacji tutaj: https://nextjs.org/docs/app/building-your-application/upgrading/version-15\",\n );\n process.exit(1);\n }\n\n await packageJson.install(\"@next/eslint-plugin-next\", { dev: true });\n }\n\n const eslintConfig = eslintConfigNames.find((configName) =>\n existsSync(path.join(root, configName)),\n );\n\n if (eslintConfig !== undefined) {\n const eslintContent = await fs.readFile(\n path.join(root, eslintConfig),\n \"utf8\",\n );\n\n if (eslintContent.includes(\"export default solvro(\")) {\n p.note(\"Eslint jest już skonfigurowany. Pomijam.\");\n\n return;\n } else {\n if (isNonInteractive) {\n // In non-interactive mode, automatically overwrite existing config\n await fs.rm(path.join(root, eslintConfig));\n } else {\n const isConfirmed = await polishConfirm({\n message: `Znaleziono plik konfiguracyjny Eslint. Czy chcesz go nadpisać?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Nadpisz plik konfiguracyjny Eslint i spróbuj ponownie.\");\n process.exit(1);\n }\n\n await fs.rm(path.join(root, eslintConfig));\n }\n }\n }\n\n const isESM = await packageJson.isESM();\n\n const eslintFilename = isESM ? \"eslint.config.js\" : \"eslint.config.mjs\";\n\n await fs.writeFile(\n path.join(root, eslintFilename),\n `import { solvro } from \"@solvro/config/eslint\";\n\nexport default solvro();\n`,\n );\n\n p.note(\"Plik konfiguracyjny Eslint został utworzony.\");\n};\n","import * as p from \"@clack/prompts\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { gitRoot, projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { adonisCi } from \"./templates/adonis-ci\";\nimport { adonisMigrationsCi } from \"./templates/adonis-ci-migrations\";\nimport { dependabot } from \"./templates/dependabot\";\nimport { nestjsCi } from \"./templates/nestjs-ci\";\nimport { reactCi } from \"./templates/react-ci\";\n\nconst packageJson = new PackageJson();\n\nexport const installGithubActions = async () => {\n const gitDirectory = gitRoot();\n const projectDirectory = projectRoot();\n await packageJson.load();\n\n const ghWorkflowsDirectory = path.join(gitDirectory, \".github/workflows\");\n await fs.mkdir(ghWorkflowsDirectory, { recursive: true });\n\n const type = await packageJson.getProjectType();\n\n const withCommitlint = await packageJson.hasPackage(\"@commitlint/cli\");\n\n if (type === \"adonis\") {\n if (!existsSync(path.join(projectDirectory, \".env.example\"))) {\n p.cancel(\n \"Nie znaleziono pliku .env.example. Upewnij się, że jesteś w katalogu projektu Adonisa.\",\n );\n process.exit(1);\n }\n\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n adonisCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"db.yml\"),\n adonisMigrationsCi(),\n );\n }\n\n if (type === \"react\") {\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n reactCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n }\n\n if (type === \"nestjs\") {\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n nestjsCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n }\n\n if (!existsSync(path.join(gitDirectory, \".github/dependabot.yml\"))) {\n await fs.writeFile(\n path.join(gitDirectory, \".github/dependabot.yml\"),\n dependabot(),\n );\n }\n\n await packageJson.addScriptIfNotExists(\"format:check\", \"prettier --check .\");\n await packageJson.addScriptIfNotExists(\"lint\", \"eslint . --max-warnings=0\");\n await packageJson.addScriptIfNotExists(\"format\", \"prettier --write .\");\n await packageJson.addScriptIfNotExists(\"typecheck\", \"tsc --noEmit\");\n\n p.note(\"Dodano konfigurację CI i skrypty.\");\n};\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const adonisCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: \"npm\"\n\n - name: Install dependencies\n run: npm ci\n\n - name: Set up AdonisJS environment\n run: |\n cp .env.example .env\n node ace generate:key\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Run prettier\n run: npm run format:check\n if: always()\n\n - name: Run Lint\n run: npm run lint\n if: always()\n\n - name: Check types\n run: npm run typecheck\n if: always()\n\n - name: Run tests\n run: npm test\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","export const commitLintCi = () => `\n - name: Check commit name\n if: github.event_name == 'pull_request'\n run: npx commitlint --from \\${{ github.event.pull_request.base.sha }} --to \\${{ github.event.pull_request.head.sha }} --verbose\n`;\n","export const adonisMigrationsCi = () => `name: Migration check\n\non:\n pull_request:\n branches: [\"*\"]\n push:\n branches: [\"main\"]\n\njobs:\n migration-check:\n runs-on: ubuntu-latest\n env:\n DB_HOST: 127.0.0.1\n DB_PORT: 5432\n DB_USER: postgres\n DB_PASSWORD: postgres\n DB_DATABASE: postgres\n\n services:\n postgres:\n image: postgres\n env:\n POSTGRES_PASSWORD: postgres\n options: >-\n --health-cmd pg_isready\n --health-interval 10s\n --health-timeout 5s\n --health-retries 5\n ports:\n - 5432:5432\n\n steps:\n - name: Check out repository code\n uses: actions/checkout@v4\n\n - name: Install dependencies\n run: npm ci\n\n - name: Set up AdonisJS environment\n run: |\n cp .env.example .env\n node ace generate:key\n\n - name: Run AdonisJS migrations\n run: node ace migration:run\n\n - name: Rollback and rerun AdonisJS migrations\n run: node ace migration:refresh\n`;\n","export const dependabot = () => `version: 2\nupdates:\n - package-ecosystem: \"npm\"\n directory: \"/\"\n schedule:\n interval: \"daily\"\n allow:\n - dependency-name: \"@solvro/config\"\n`;\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const nestjsCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: \"npm\"\n\n - name: Install dependencies\n run: npm ci\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Run prettier\n run: npm run format:check\n if: always()\n\n - name: Run Lint\n run: npm run lint\n if: always()\n\n - name: Check types\n run: npm run typecheck\n if: always()\n\n - name: Run tests\n run: npm test\n if: always()\n\n - name: Run e2e tests\n run: npm run test:e2e\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const reactCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: 'npm'\n\n - name: Install dependencies\n run: npm ci\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Format check\n run: npm run format:check\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","import assert from \"node:assert\";\nimport { writeFile } from \"node:fs/promises\";\n\nimport { PackageJson } from \"../utils/package-json\";\nimport { installHusky } from \"./install-husky\";\n\nconst packageJson = new PackageJson();\n\nexport const installLintStaged = async () => {\n await packageJson.load();\n\n assert.ok(packageJson.json !== null);\n\n await installHusky();\n\n await packageJson.install(\"lint-staged\", { dev: true });\n\n await writeFile(\".husky/pre-commit\", \"npx lint-staged\\n\");\n\n packageJson.json[\"lint-staged\"] = {\n \"*\": \"prettier -w --ignore-unknown\",\n };\n\n await packageJson.save();\n};\n","import * as p from \"@clack/prompts\";\nimport assert from \"node:assert\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\n\nconst prettierConfigNames = [\n \".prettierrc.js\",\n \".prettierrc.cjs\",\n \".prettierrc.yaml\",\n \".prettierrc.yml\",\n \".prettierrc.json\",\n \".prettierrc\",\n \"prettier.config.js\",\n \"prettier.config.mjs\",\n \"prettier.config.cjs\",\n \"prettier.config.ts\",\n \"prettier.config.mts\",\n \"prettier.config.cts\",\n];\n\nconst packageJson = new PackageJson();\n\nexport const installPrettier = async (isNonInteractive = false) => {\n const root = projectRoot();\n\n await packageJson.load();\n assert.ok(packageJson.json !== null);\n\n await packageJson.install(\"prettier\", { dev: true, minVersion: \">=3\" });\n\n const prettierConfig = prettierConfigNames.find((configName) =>\n existsSync(path.join(root, configName)),\n );\n\n const solvroPrettierPath = \"@solvro/config/prettier\";\n\n if (prettierConfig !== undefined || packageJson.json.prettier !== undefined) {\n if (packageJson.json.prettier === solvroPrettierPath) {\n p.note(\"Konfiguracja Prettiera jest już ustawiona. Pomijam.\");\n return;\n }\n\n if (isNonInteractive) {\n // In non-interactive mode, automatically overwrite existing config\n for (const configName of prettierConfigNames) {\n await fs.rm(path.join(root, configName)).catch(() => null);\n }\n } else {\n const isConfirmed = await polishConfirm({\n message: `Znaleziono konfigurację Prettiera. Czy chcesz ją nadpisać?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Usuń konfiguracje Prettiera i spróbuj ponownie.\");\n process.exit(1);\n }\n\n for (const configName of prettierConfigNames) {\n await fs.rm(path.join(root, configName)).catch(() => null);\n }\n }\n }\n\n packageJson.json.prettier = solvroPrettierPath;\n\n await packageJson.save();\n\n p.note(\"Konfiguracja Prettiera została dodana.\");\n};\n"],"mappings":"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","names":["p","path","execSync","path","options","spinner","p","isInteractive","writeFile","path","assert","assert","packageJson","writeFile","path","p","path","packageJson","isNonInteractive","root","path","p","existsSync","fs","path","packageJson","path","existsSync","assert","writeFile","packageJson","assert","writeFile","p","assert","existsSync","fs","path","packageJson","isNonInteractive","root","assert","existsSync","path","packageJson"]}
1
+ {"version":3,"sources":["../../src/cli/index.ts","../../package.json","../../src/utils/is-git-clean.ts","../../src/utils/package-json.ts","../../src/utils/git-root.ts","../../src/utils/$$.ts","../../src/utils/run-if-interactive.ts","../../src/utils/polish-confirm.ts","../../src/cli/install-commitlint.ts","../../src/cli/install-husky.ts","../../src/cli/templates/commitlint.ts","../../src/cli/install-eslint.ts","../../src/cli/install-ga.ts","../../src/cli/templates/commit-lint-ci.ts","../../src/cli/templates/adonis-ci.ts","../../src/cli/templates/adonis-ci-migrations.ts","../../src/cli/templates/dependabot.ts","../../src/cli/templates/nestjs-ci.ts","../../src/cli/templates/react-ci.ts","../../src/cli/install-lint-staged.ts","../../src/cli/install-prettier.ts"],"sourcesContent":["import * as p from \"@clack/prompts\";\nimport { Command } from \"commander\";\nimport { getUserAgent } from \"package-manager-detector/detect\";\nimport c from \"picocolors\";\n\nimport packageJsonData from \"../../package.json\";\nimport { isGitClean } from \"../utils/is-git-clean\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\nimport { installCommitLint } from \"./install-commitlint\";\nimport { installEslint } from \"./install-eslint\";\nimport { installGithubActions } from \"./install-ga\";\nimport { installLintStaged } from \"./install-lint-staged\";\nimport { installPrettier } from \"./install-prettier\";\n\n// Types\ninterface CliOptions {\n force?: boolean;\n eslint?: boolean;\n prettier?: boolean;\n ghAction?: boolean;\n commitlint?: boolean;\n all?: boolean;\n}\n\n// CLI setup\nconst program = new Command();\nprogram\n .name(\"@solvro/config\")\n .description(\"Solvro's engineering style guide setup\")\n .version(packageJsonData.version)\n .option(\"-f, --force\", \"Skip git clean check\", false)\n .option(\"--eslint\", \"Install ESLint configuration\", false)\n .option(\"--prettier\", \"Install Prettier configuration\", false)\n .option(\"--gh-action\", \"Install GitHub Actions\", false)\n .option(\"--commitlint\", \"Install Commitlint configuration\", false)\n .option(\"-a, --all\", \"Install all tools\", false);\n\nprogram.parse();\nconst options: CliOptions = program.opts();\n\n// Check if running in non-interactive mode (any CLI flags provided)\nconst isNonInteractive = process.argv.length > 2;\n\nasync function main() {\n if (!isNonInteractive) {\n p.intro(c.bold(c.bgBlue(\" @solvro/config \")));\n }\n\n const userAgent = getUserAgent();\n\n if (userAgent !== \"npm\") {\n const packageManager = userAgent ?? \"unknown\";\n const warningMessage = `\n${c.red(c.bold(`⚠️ OSTRZEŻENIE: ${packageManager} nie jest obsługiwany ⚠️`))}\n\nPróbujesz uruchomić ten skrypt z ${c.yellow(packageManager)}'em, ale @solvro/config działa tylko z ${c.yellow(\"npm'em\")}. \n\nSupport dla innych menedżerów pakietów nie jest planowany - chcemy jednolitego stacku technologicznego dla projektów w naszym kochanym kole Solvro.\n\nUżyj zamiast tego npm'a:\n${c.cyan(\"npx @solvro/config\")}`;\n\n if (isNonInteractive) {\n console.error(warningMessage);\n } else {\n p.cancel(warningMessage);\n }\n process.exit(1);\n }\n\n // Git clean check\n if (options.force !== true && !isGitClean()) {\n if (isNonInteractive) {\n console.error(\n \"Repozytorium Git ma niezatwierdzone zmiany. Użyj --force, aby pominąć to sprawdzenie.\",\n );\n process.exit(1);\n }\n\n const isConfirmed = await polishConfirm({\n message: `Masz niezapisane zmiany w Git. Czy chcesz kontynuować?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zapisz zmiany w Git i spróbuj ponownie.\");\n process.exit(1);\n }\n }\n\n const packageJson = new PackageJson();\n\n // Determine project type automatically\n const projectType = await packageJson.getProjectType();\n\n // Project type confirmation (interactive mode only)\n if (!isNonInteractive) {\n if (projectType === \"adonis\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał Adonisa. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zgłoś błąd na GitHubie :(, a my spróbujemy pomóc.\");\n process.exit(1);\n }\n }\n\n if (projectType === \"react\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał Reacta. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed)) {\n p.cancel(\"😡\");\n process.exit(1);\n }\n\n if (!isConfirmed) {\n p.cancel(\"Zgłoś błąd na GitHubie :(, a my spróbujemy pomóc.\");\n process.exit(1);\n }\n }\n\n if (projectType === \"nestjs\") {\n const isConfirmed = await polishConfirm({\n message: `Wygląda jakbyś używał NestJsa. Czy to się zgadza?`,\n });\n\n if (p.isCancel(isConfirmed)) {\n p.cancel(\"😡\");\n process.exit(1);\n }\n }\n\n if (projectType === \"node\") {\n p.cancel(\n \"Nie znaleziono ani Adonisa, Reacta, ani NestJsa. Musisz ręcznie konfigurować projekt.\",\n );\n process.exit(1);\n }\n }\n if (projectType === \"adonis\" || projectType === \"react\") {\n if (isNonInteractive) {\n await packageJson.ensureESM();\n } else {\n if (!(await packageJson.isESM())) {\n const isConfirmed = await polishConfirm({\n message: `Twój projekt nie używa ESM (brak type: \"module\" w package.json). Czy chcesz to dodać? (Wymagane by kontynuować)`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Zmień projekt na ESM i spróbuj ponownie.\");\n process.exit(1);\n }\n\n await packageJson.ensureESM();\n }\n }\n }\n\n // Determine which tools to install\n let toolsToInstall: string[] = [];\n\n if (options.all === true) {\n toolsToInstall = [\"eslint\", \"prettier\", \"gh-action\", \"commitlint\"];\n } else if (isNonInteractive) {\n // In non-interactive mode, only install explicitly requested tools\n if (options.eslint === true) {\n toolsToInstall.push(\"eslint\");\n }\n if (options.prettier === true) {\n toolsToInstall.push(\"prettier\");\n }\n if (options.ghAction === true) {\n toolsToInstall.push(\"gh-action\");\n }\n if (options.commitlint === true) {\n toolsToInstall.push(\"commitlint\");\n }\n\n if (toolsToInstall.length === 0) {\n console.error(\n \"Nie wybrano żadnych narzędzi. Użyj --eslint, --prettier, --gh-action, --commitlint, lub --all\",\n );\n process.exit(1);\n }\n } else {\n // Interactive mode\n const additionalTools = await p.multiselect({\n message: `Które rzeczy Cię interesują? ${c.gray(\"zaznacz spacją, potwierdź enterem\")}`,\n initialValues: [\"eslint\", \"prettier\", \"gh-action\", \"commitlint\"],\n options: [\n {\n value: \"eslint\",\n label: c.bold(c.blueBright(\"ESLint\")),\n hint: \"sprawdzanie jakości kodu\",\n },\n {\n value: \"prettier\",\n label: c.bold(c.yellowBright(\"Prettier\")),\n hint: \"formatowanie\",\n },\n {\n value: \"gh-action\",\n label: c.bold(\"GitHub Actions\"),\n hint: \"automatyczne testy na Githubie\",\n },\n {\n value: \"commitlint\",\n label: c.bold(\"Commitlint\"),\n hint: \"walidacja treści commitów\",\n },\n ],\n required: false,\n });\n\n if (p.isCancel(additionalTools) || additionalTools.length === 0) {\n p.cancel(\"Nie wybrano żadnych narzędzi.\");\n process.exit(1);\n }\n\n toolsToInstall = additionalTools;\n }\n\n // Install the base package\n await packageJson.install(\"@solvro/config\", {\n dev: true,\n alwaysUpdate: !isNonInteractive,\n });\n\n // Install selected tools\n if (toolsToInstall.includes(\"eslint\")) {\n await installEslint(isNonInteractive);\n }\n\n if (toolsToInstall.includes(\"prettier\")) {\n await installPrettier(isNonInteractive);\n await installLintStaged();\n }\n\n if (toolsToInstall.includes(\"commitlint\")) {\n await installCommitLint();\n }\n\n if (toolsToInstall.includes(\"gh-action\")) {\n await installGithubActions();\n }\n\n await packageJson.clearInstall();\n\n if (isNonInteractive) {\n console.log(\"✅ Konfiguracja zakończona pomyślnie!\");\n } else {\n p.outro(\"✅ Konfiguracja zakończona pomyślnie!\");\n }\n}\n\n// Run the main function\ntry {\n await main();\n} catch (error: unknown) {\n console.error(\"Wystąpił błąd:\", error);\n process.exit(1);\n}\n","{\n \"name\": \"@solvro/config\",\n \"version\": \"2.0.3\",\n \"description\": \"Solvro's engineering style guide\",\n \"keywords\": [\n \"eslint\",\n \"prettier\",\n \"solvro\"\n ],\n \"homepage\": \"https://github.com/Solvro/lib-web-solvro-config#readme\",\n \"bugs\": {\n \"url\": \"https://github.com/Solvro/lib-web-solvro-config/issues\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/Solvro/lib-web-solvro-config.git\"\n },\n \"license\": \"MPL-2.0\",\n \"type\": \"module\",\n \"exports\": {\n \"./eslint\": {\n \"types\": \"./dist/eslint/index.d.ts\",\n \"import\": \"./dist/eslint/index.js\",\n \"require\": \"./dist/eslint/index.cjs\"\n },\n \"./prettier\": {\n \"types\": \"./dist/prettier/index.d.ts\",\n \"import\": \"./dist/prettier/index.js\",\n \"require\": \"./dist/prettier/index.cjs\"\n },\n \"./commitlint\": {\n \"types\": \"./dist/commitlint/index.d.ts\",\n \"import\": \"./dist/commitlint/index.js\",\n \"require\": \"./dist/commitlint/index.cjs\"\n }\n },\n \"bin\": \"./bin/index.js\",\n \"files\": [\n \"dist\"\n ],\n \"scripts\": {\n \"build\": \"tsup\",\n \"build:watch\": \"tsup --watch\",\n \"cli\": \"tsx ./src/cli/index.ts\",\n \"dev\": \"npx @eslint/config-inspector\",\n \"format\": \"prettier --check .\",\n \"knip\": \"knip\",\n \"lint\": \"eslint .\",\n \"prepare\": \"husky || true\",\n \"prepublish\": \"npm run build\",\n \"release\": \"semantic-release\",\n \"test\": \"vitest run\",\n \"test:ui\": \"vitest --ui\",\n \"test:watch\": \"vitest\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"lint-staged\": {\n \"*\": \"prettier -w --ignore-unknown\"\n },\n \"prettier\": \"./dist/prettier/index.js\",\n \"dependencies\": {\n \"@adonisjs/eslint-config\": \"^2.1.0\",\n \"@clack/prompts\": \"^0.11.0\",\n \"@commitlint/config-conventional\": \"^19.8.1\",\n \"@darraghor/eslint-plugin-nestjs-typed\": \"^6.7.0\",\n \"@eslint-community/eslint-plugin-eslint-comments\": \"^4.5.0\",\n \"@eslint/js\": \"^9.30.1\",\n \"@tanstack/eslint-plugin-query\": \"^5.81.2\",\n \"@trivago/prettier-plugin-sort-imports\": \"^5.2.2\",\n \"@typescript-eslint/eslint-plugin\": \"^8.35.1\",\n \"commander\": \"^14.0.0\",\n \"eslint-config-flat-gitignore\": \"^2.1.0\",\n \"eslint-config-prettier\": \"^10.1.5\",\n \"eslint-plugin-antfu\": \"^3.1.1\",\n \"eslint-plugin-import\": \"^2.32.0\",\n \"eslint-plugin-jsdoc\": \"^51.3.3\",\n \"eslint-plugin-jsx-a11y\": \"^6.10.2\",\n \"eslint-plugin-n\": \"^17.21.0\",\n \"eslint-plugin-react\": \"^7.37.5\",\n \"eslint-plugin-react-hooks\": \"^5.2.0\",\n \"eslint-plugin-react-refresh\": \"^0.4.16\",\n \"eslint-plugin-react-you-might-not-need-an-effect\": \"^0.4.1\",\n \"eslint-plugin-unicorn\": \"^59.0.1\",\n \"eslint-plugin-unused-imports\": \"^4.1.4\",\n \"execa\": \"^9.6.0\",\n \"find-up-simple\": \"^1.0.1\",\n \"globals\": \"^16.3.0\",\n \"is-interactive\": \"^2.0.0\",\n \"local-pkg\": \"^1.1.1\",\n \"package-manager-detector\": \"^1.3.0\",\n \"picocolors\": \"^1.1.1\",\n \"prettier-plugin-packagejson\": \"^2.5.18\",\n \"prettier-plugin-tailwindcss\": \"^0.6.13\",\n \"semver\": \"^7.7.2\",\n \"typescript-eslint\": \"^8.35.1\"\n },\n \"devDependencies\": {\n \"@commitlint/cli\": \"^19.8.1\",\n \"@eslint/config-inspector\": \"^1.1.0\",\n \"@next/eslint-plugin-next\": \"^15.3.5\",\n \"@semantic-release/git\": \"^10.0.1\",\n \"@types/node\": \"^24.0.10\",\n \"@types/semver\": \"^7.7.0\",\n \"@vitest/coverage-v8\": \"^3.2.4\",\n \"@vitest/ui\": \"^3.2.4\",\n \"eslint\": \"^9.30.1\",\n \"husky\": \"^9.1.7\",\n \"knip\": \"^5.61.3\",\n \"lint-staged\": \"^16.1.2\",\n \"prettier\": \"^3.6.2\",\n \"semantic-release\": \"^24.2.6\",\n \"tsup\": \"^8.5.0\",\n \"tsx\": \"^4.20.3\",\n \"typescript\": \"^5.8.3\",\n \"vitest\": \"^3.2.4\"\n },\n \"peerDependencies\": {\n \"@next/eslint-plugin-next\": \">=12.3.0 <16.0.0-0\",\n \"eslint\": \">=9.0.0 <10.0.0\"\n },\n \"packageManager\": \"npm@11.4.2\",\n \"engines\": {\n \"node\": \"^20.19.0 || >=22.12.0\"\n },\n \"volta\": {\n \"node\": \"22.17.0\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n }\n}\n","import { execSync } from \"node:child_process\";\n\nexport function isGitClean(): boolean {\n try {\n execSync(\"git diff-index --quiet HEAD --\");\n return true;\n } catch {\n return false;\n }\n}\n","import * as p from \"@clack/prompts\";\nimport { getPackageInfo, isPackageListed, loadPackageJSON } from \"local-pkg\";\nimport assert from \"node:assert\";\nimport { writeFile } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport semver from \"semver\";\n\nimport { $$ } from \"./$$\";\nimport { projectRoot } from \"./git-root\";\nimport { runIfInteractive } from \"./run-if-interactive\";\n\nexport class PackageJson {\n public json: Awaited<ReturnType<typeof loadPackageJSON>> = null;\n\n async load() {\n const json = await loadPackageJSON(projectRoot());\n\n if (json === null) {\n p.cancel(\n \"Nie znaleziono package.json. Upewnij się, że jesteś w katalogu projektu.\",\n );\n process.exit(1);\n }\n\n this.json = json;\n }\n\n hasPackage(package_: string) {\n return isPackageListed(package_);\n }\n\n async doesSatisfies(package_: string, version: string) {\n await this.load();\n\n assert.ok(this.json !== null);\n\n const packageInfo = await getPackageInfo(package_);\n\n if (packageInfo?.version === undefined) {\n return false;\n }\n\n return semver.satisfies(packageInfo.version, version);\n }\n\n async isESM() {\n await this.load();\n\n assert.ok(this.json !== null);\n\n return this.json.type === \"module\";\n }\n\n async ensureESM() {\n if (await this.isESM()) {\n return;\n }\n\n assert.ok(this.json !== null);\n\n this.json.type = \"module\";\n\n await this.save();\n }\n\n async getProjectType() {\n const isAdonis = await isPackageListed(\"@adonisjs/core\");\n const isReact = await isPackageListed(\"react\");\n const isNestJs = await isPackageListed(\"@nestjs/core\");\n if (isReact && isAdonis) {\n throw new Error(\n \"You can't use both Adonis and React in the same project\",\n );\n }\n\n if (isNestJs) {\n return \"nestjs\";\n }\n\n if (isAdonis) {\n return \"adonis\";\n }\n\n if (isReact) {\n return \"react\";\n }\n\n return \"node\";\n }\n\n async save() {\n await writeFile(\n path.join(projectRoot(), \"package.json\"),\n JSON.stringify(this.json, null, 2),\n );\n }\n\n async addScriptIfNotExists(name: string, script: string) {\n await this.load();\n\n assert.ok(this.json !== null);\n\n if (this.json.scripts?.[name] !== undefined) {\n return;\n }\n\n this.json.scripts = this.json.scripts ?? {};\n this.json.scripts[name] = script;\n\n await this.save();\n }\n\n async install(\n package_: string,\n options?: { minVersion?: string; dev?: boolean; alwaysUpdate?: boolean },\n ) {\n const isInstalled = await this.hasPackage(package_);\n\n if (!isInstalled) {\n const spinner = p.spinner();\n runIfInteractive(() => {\n spinner.start(`Instalowanie ${package_}`);\n });\n\n await $$`npm i ${options?.dev === true ? \"-D\" : \"\"} ${package_}@latest`;\n runIfInteractive(() => {\n spinner.stop(`${package_} zainstalowany 😍`);\n });\n\n await this.load();\n\n return;\n }\n\n const info = await getPackageInfo(package_);\n\n if (\n (info?.version !== undefined &&\n options?.minVersion !== undefined &&\n !semver.satisfies(info.version, options.minVersion)) ||\n options?.alwaysUpdate === true\n ) {\n const spinner = p.spinner();\n runIfInteractive(() => {\n spinner.start(`Aktualizowanie ${package_}`);\n });\n await $$`npm i ${options.dev === true ? \"-D\" : \"\"} ${package_}@latest`;\n runIfInteractive(() => {\n spinner.stop(`${package_} zaktualizowany 😍`);\n });\n\n await this.load();\n }\n }\n\n async clearInstall() {\n await $$`npm ci`;\n }\n}\n","import { findUpSync } from \"find-up-simple\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\n\nexport const projectRoot = () => {\n const packageJsonPath = findUpSync(\"package.json\");\n\n if (packageJsonPath !== undefined) {\n return path.dirname(packageJsonPath);\n }\n\n return process.cwd();\n};\n\nexport const gitRoot = () => {\n try {\n const rootDirectory = execSync(\"git rev-parse --show-toplevel\", {\n cwd: projectRoot(),\n });\n return rootDirectory.toString().trim();\n } catch {\n return projectRoot();\n }\n};\n","import type { ExecaScriptMethod } from \"execa\";\n\nimport { projectRoot } from \"./git-root\";\n\nlet cachedExeca: ExecaScriptMethod | null = null;\n\nexport const $$ = (async (...arguments_: Parameters<ExecaScriptMethod>) => {\n if (cachedExeca === null) {\n const { $ } = await import(\"execa\");\n cachedExeca = $({\n cwd: projectRoot(),\n });\n }\n return cachedExeca(...arguments_);\n}) as ExecaScriptMethod;\n","import isInteractive from \"is-interactive\";\n\nexport const runIfInteractive = <T>(function_: () => T): T | undefined => {\n if (isInteractive()) {\n return function_();\n }\n\n return undefined;\n};\n","import * as p from \"@clack/prompts\";\nimport isInteractive from \"is-interactive\";\n\nexport const polishConfirm = async (props: p.ConfirmOptions) => {\n if (!isInteractive()) {\n return true;\n }\n\n return p.confirm({\n active: \"Tak\",\n inactive: \"Nie\",\n ...props,\n });\n};\n","import { writeFile } from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { installHusky } from \"./install-husky\";\nimport { commitlint } from \"./templates/commitlint\";\n\nconst root = projectRoot();\n\nconst packageJson = new PackageJson();\n\nexport const installCommitLint = async () => {\n await installHusky();\n\n await packageJson.install(\"@commitlint/cli\", { dev: true });\n\n await writeFile(\n path.join(root, \".husky/commit-msg\"),\n 'npx commitlint --edit \"$1\"\\n',\n );\n\n await writeFile(path.join(root, \".commitlintrc.js\"), commitlint());\n};\n","import assert from \"node:assert\";\n\nimport { $$ } from \"../utils/$$\";\nimport { PackageJson } from \"../utils/package-json\";\n\nconst packageJson = new PackageJson();\n\nexport const installHusky = async () => {\n if (!(await packageJson.hasPackage(\"husky\"))) {\n await packageJson.install(\"husky\", { dev: true });\n await $$`npx husky init`;\n }\n\n await packageJson.load();\n\n assert.ok(packageJson.json !== null);\n\n packageJson.json.scripts = packageJson.json.scripts ?? {};\n packageJson.json.scripts.prepare = `husky || true`;\n\n await packageJson.save();\n};\n","export const commitlint = () => `export default {\n extends: [\"@solvro/config/commitlint\"],\n};\n`;\n","import * as p from \"@clack/prompts\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\n\nconst eslintConfigNames = [\n \".eslintrc.js\",\n \".eslintrc.cjs\",\n \".eslintrc.yaml\",\n \".eslintrc.yml\",\n \".eslintrc.json\",\n \".eslintrc\",\n \"eslint.config.js\",\n \"eslint.config.mjs\",\n \"eslint.config.cjs\",\n \"eslint.config.ts\",\n \"eslint.config.mts\",\n \"eslint.config.cts\",\n];\n\nconst packageJson = new PackageJson();\n\nexport const installEslint = async (isNonInteractive = false) => {\n const root = projectRoot();\n\n await packageJson.load();\n\n await packageJson.install(\"eslint\", { dev: true, minVersion: \">=9\" });\n\n const type = await packageJson.getProjectType();\n\n if (type === \"react\" && (await packageJson.hasPackage(\"next\"))) {\n const is15 = await packageJson.doesSatisfies(\"next\", \">=15\");\n\n if (!is15) {\n p.cancel(\n \"Next.js musi być w conajmniej wersji 15. Zaktualizuj Next.js i spróbuj ponownie.\\nWięcej informacji tutaj: https://nextjs.org/docs/app/building-your-application/upgrading/version-15\",\n );\n process.exit(1);\n }\n\n await packageJson.install(\"@next/eslint-plugin-next\", { dev: true });\n }\n\n const eslintConfig = eslintConfigNames.find((configName) =>\n existsSync(path.join(root, configName)),\n );\n\n if (eslintConfig !== undefined) {\n const eslintContent = await fs.readFile(\n path.join(root, eslintConfig),\n \"utf8\",\n );\n\n if (eslintContent.includes(\"export default solvro(\")) {\n p.note(\"Eslint jest już skonfigurowany. Pomijam.\");\n\n return;\n } else {\n if (isNonInteractive) {\n // In non-interactive mode, automatically overwrite existing config\n await fs.rm(path.join(root, eslintConfig));\n } else {\n const isConfirmed = await polishConfirm({\n message: `Znaleziono plik konfiguracyjny Eslint. Czy chcesz go nadpisać?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Nadpisz plik konfiguracyjny Eslint i spróbuj ponownie.\");\n process.exit(1);\n }\n\n await fs.rm(path.join(root, eslintConfig));\n }\n }\n }\n\n const isESM = await packageJson.isESM();\n\n const eslintFilename = isESM ? \"eslint.config.js\" : \"eslint.config.mjs\";\n\n await fs.writeFile(\n path.join(root, eslintFilename),\n `import { solvro } from \"@solvro/config/eslint\";\n\nexport default solvro();\n`,\n );\n\n p.note(\"Plik konfiguracyjny Eslint został utworzony.\");\n};\n","import * as p from \"@clack/prompts\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { gitRoot, projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { adonisCi } from \"./templates/adonis-ci\";\nimport { adonisMigrationsCi } from \"./templates/adonis-ci-migrations\";\nimport { dependabot } from \"./templates/dependabot\";\nimport { nestjsCi } from \"./templates/nestjs-ci\";\nimport { reactCi } from \"./templates/react-ci\";\n\nconst packageJson = new PackageJson();\n\nexport const installGithubActions = async () => {\n const gitDirectory = gitRoot();\n const projectDirectory = projectRoot();\n await packageJson.load();\n\n const ghWorkflowsDirectory = path.join(gitDirectory, \".github/workflows\");\n await fs.mkdir(ghWorkflowsDirectory, { recursive: true });\n\n const type = await packageJson.getProjectType();\n\n const withCommitlint = await packageJson.hasPackage(\"@commitlint/cli\");\n\n if (type === \"adonis\") {\n if (!existsSync(path.join(projectDirectory, \".env.example\"))) {\n p.cancel(\n \"Nie znaleziono pliku .env.example. Upewnij się, że jesteś w katalogu projektu Adonisa.\",\n );\n process.exit(1);\n }\n\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n adonisCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"db.yml\"),\n adonisMigrationsCi(),\n );\n }\n\n if (type === \"react\") {\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n reactCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n }\n\n if (type === \"nestjs\") {\n await fs.writeFile(\n path.join(ghWorkflowsDirectory, \"ci.yml\"),\n nestjsCi({\n nodeVersion: \"22\",\n withCommitlint,\n }),\n );\n }\n\n if (!existsSync(path.join(gitDirectory, \".github/dependabot.yml\"))) {\n await fs.writeFile(\n path.join(gitDirectory, \".github/dependabot.yml\"),\n dependabot(),\n );\n }\n\n await packageJson.addScriptIfNotExists(\"format:check\", \"prettier --check .\");\n await packageJson.addScriptIfNotExists(\"lint\", \"eslint . --max-warnings=0\");\n await packageJson.addScriptIfNotExists(\"format\", \"prettier --write .\");\n await packageJson.addScriptIfNotExists(\"typecheck\", \"tsc --noEmit\");\n\n p.note(\"Dodano konfigurację CI i skrypty.\");\n};\n","export const commitLintCi = () => `\n - name: Check commit name\n if: github.event_name == 'pull_request'\n run: npx commitlint --from \\${{ github.event.pull_request.base.sha }} --to \\${{ github.event.pull_request.head.sha }} --verbose\n`;\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const adonisCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: \"npm\"\n\n - name: Install dependencies\n run: npm ci\n\n - name: Set up AdonisJS environment\n run: |\n cp .env.example .env\n node ace generate:key\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Run prettier\n run: npm run format:check\n if: always()\n\n - name: Run Lint\n run: npm run lint\n if: always()\n\n - name: Check types\n run: npm run typecheck\n if: always()\n\n - name: Run tests\n run: npm test\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","export const adonisMigrationsCi = () => `name: Migration check\n\non:\n pull_request:\n branches: [\"*\"]\n push:\n branches: [\"main\"]\n\njobs:\n migration-check:\n runs-on: ubuntu-latest\n env:\n DB_HOST: 127.0.0.1\n DB_PORT: 5432\n DB_USER: postgres\n DB_PASSWORD: postgres\n DB_DATABASE: postgres\n\n services:\n postgres:\n image: postgres\n env:\n POSTGRES_PASSWORD: postgres\n options: >-\n --health-cmd pg_isready\n --health-interval 10s\n --health-timeout 5s\n --health-retries 5\n ports:\n - 5432:5432\n\n steps:\n - name: Check out repository code\n uses: actions/checkout@v4\n\n - name: Install dependencies\n run: npm ci\n\n - name: Set up AdonisJS environment\n run: |\n cp .env.example .env\n node ace generate:key\n\n - name: Run AdonisJS migrations\n run: node ace migration:run\n\n - name: Rollback and rerun AdonisJS migrations\n run: node ace migration:refresh\n`;\n","export const dependabot = () => `version: 2\nupdates:\n - package-ecosystem: \"npm\"\n directory: \"/\"\n schedule:\n interval: \"daily\"\n allow:\n - dependency-name: \"@solvro/config\"\n`;\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const nestjsCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: \"npm\"\n\n - name: Install dependencies\n run: npm ci\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Run prettier\n run: npm run format:check\n if: always()\n\n - name: Run Lint\n run: npm run lint\n if: always()\n\n - name: Check types\n run: npm run typecheck\n if: always()\n\n - name: Run tests\n run: npm test\n if: always()\n\n - name: Run e2e tests\n run: npm run test:e2e\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","import { commitLintCi } from \"./commit-lint-ci\";\n\nexport const reactCi = ({\n nodeVersion,\n withCommitlint,\n}: {\n nodeVersion: string;\n withCommitlint: boolean;\n}) => `name: CI\n\non:\n push:\n branches: [\"main\"]\n pull_request:\n\njobs:\n lint:\n runs-on: ubuntu-latest\n steps:\n - name: Checkout\n uses: actions/checkout@v4\n with:\n fetch-depth: 0\n\n - name: Setup node\n uses: actions/setup-node@v4\n with:\n node-version: ${nodeVersion}\n cache: 'npm'\n\n - name: Install dependencies\n run: npm ci\n${withCommitlint ? commitLintCi() : \"\"}\n - name: Format check\n run: npm run format:check\n if: always()\n\n - name: Build\n run: npm run build\n if: always()`;\n","import assert from \"node:assert\";\nimport { writeFile } from \"node:fs/promises\";\n\nimport { PackageJson } from \"../utils/package-json\";\nimport { installHusky } from \"./install-husky\";\n\nconst packageJson = new PackageJson();\n\nexport const installLintStaged = async () => {\n await packageJson.load();\n\n assert.ok(packageJson.json !== null);\n\n await installHusky();\n\n await packageJson.install(\"lint-staged\", { dev: true });\n\n await writeFile(\".husky/pre-commit\", \"npx lint-staged\\n\");\n\n packageJson.json[\"lint-staged\"] = {\n \"*\": \"prettier -w --ignore-unknown\",\n };\n\n await packageJson.save();\n};\n","import * as p from \"@clack/prompts\";\nimport assert from \"node:assert\";\nimport { existsSync } from \"node:fs\";\nimport * as fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nimport { projectRoot } from \"../utils/git-root\";\nimport { PackageJson } from \"../utils/package-json\";\nimport { polishConfirm } from \"../utils/polish-confirm\";\n\nconst prettierConfigNames = [\n \".prettierrc.js\",\n \".prettierrc.cjs\",\n \".prettierrc.yaml\",\n \".prettierrc.yml\",\n \".prettierrc.json\",\n \".prettierrc\",\n \"prettier.config.js\",\n \"prettier.config.mjs\",\n \"prettier.config.cjs\",\n \"prettier.config.ts\",\n \"prettier.config.mts\",\n \"prettier.config.cts\",\n];\n\nconst packageJson = new PackageJson();\n\nexport const installPrettier = async (isNonInteractive = false) => {\n const root = projectRoot();\n\n await packageJson.load();\n assert.ok(packageJson.json !== null);\n\n await packageJson.install(\"prettier\", { dev: true, minVersion: \">=3\" });\n\n const prettierConfig = prettierConfigNames.find((configName) =>\n existsSync(path.join(root, configName)),\n );\n\n const solvroPrettierPath = \"@solvro/config/prettier\";\n\n if (prettierConfig !== undefined || packageJson.json.prettier !== undefined) {\n if (packageJson.json.prettier === solvroPrettierPath) {\n p.note(\"Konfiguracja Prettiera jest już ustawiona. Pomijam.\");\n return;\n }\n\n if (isNonInteractive) {\n // In non-interactive mode, automatically overwrite existing config\n for (const configName of prettierConfigNames) {\n await fs.rm(path.join(root, configName)).catch(() => null);\n }\n } else {\n const isConfirmed = await polishConfirm({\n message: `Znaleziono konfigurację Prettiera. Czy chcesz ją nadpisać?`,\n });\n\n if (p.isCancel(isConfirmed) || !isConfirmed) {\n p.cancel(\"Usuń konfiguracje Prettiera i spróbuj ponownie.\");\n process.exit(1);\n }\n\n for (const configName of prettierConfigNames) {\n await fs.rm(path.join(root, configName)).catch(() => null);\n }\n }\n }\n\n packageJson.json.prettier = solvroPrettierPath;\n\n await packageJson.save();\n\n p.note(\"Konfiguracja Prettiera została dodana.\");\n};\n"],"mappings":";AAAA,YAAYA,QAAO;AACnB,SAAS,eAAe;AACxB,SAAS,oBAAoB;AAC7B,OAAO,OAAO;;;ACHd;AAAA,EACE,MAAQ;AAAA,EACR,SAAW;AAAA,EACX,aAAe;AAAA,EACf,UAAY;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA,EACA,UAAY;AAAA,EACZ,MAAQ;AAAA,IACN,KAAO;AAAA,EACT;AAAA,EACA,YAAc;AAAA,IACZ,MAAQ;AAAA,IACR,KAAO;AAAA,EACT;AAAA,EACA,SAAW;AAAA,EACX,MAAQ;AAAA,EACR,SAAW;AAAA,IACT,YAAY;AAAA,MACV,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,IACA,cAAc;AAAA,MACZ,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,IACA,gBAAgB;AAAA,MACd,OAAS;AAAA,MACT,QAAU;AAAA,MACV,SAAW;AAAA,IACb;AAAA,EACF;AAAA,EACA,KAAO;AAAA,EACP,OAAS;AAAA,IACP;AAAA,EACF;AAAA,EACA,SAAW;AAAA,IACT,OAAS;AAAA,IACT,eAAe;AAAA,IACf,KAAO;AAAA,IACP,KAAO;AAAA,IACP,QAAU;AAAA,IACV,MAAQ;AAAA,IACR,MAAQ;AAAA,IACR,SAAW;AAAA,IACX,YAAc;AAAA,IACd,SAAW;AAAA,IACX,MAAQ;AAAA,IACR,WAAW;AAAA,IACX,cAAc;AAAA,IACd,WAAa;AAAA,EACf;AAAA,EACA,eAAe;AAAA,IACb,KAAK;AAAA,EACP;AAAA,EACA,UAAY;AAAA,EACZ,cAAgB;AAAA,IACd,2BAA2B;AAAA,IAC3B,kBAAkB;AAAA,IAClB,mCAAmC;AAAA,IACnC,yCAAyC;AAAA,IACzC,mDAAmD;AAAA,IACnD,cAAc;AAAA,IACd,iCAAiC;AAAA,IACjC,yCAAyC;AAAA,IACzC,oCAAoC;AAAA,IACpC,WAAa;AAAA,IACb,gCAAgC;AAAA,IAChC,0BAA0B;AAAA,IAC1B,uBAAuB;AAAA,IACvB,wBAAwB;AAAA,IACxB,uBAAuB;AAAA,IACvB,0BAA0B;AAAA,IAC1B,mBAAmB;AAAA,IACnB,uBAAuB;AAAA,IACvB,6BAA6B;AAAA,IAC7B,+BAA+B;AAAA,IAC/B,oDAAoD;AAAA,IACpD,yBAAyB;AAAA,IACzB,gCAAgC;AAAA,IAChC,OAAS;AAAA,IACT,kBAAkB;AAAA,IAClB,SAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,aAAa;AAAA,IACb,4BAA4B;AAAA,IAC5B,YAAc;AAAA,IACd,+BAA+B;AAAA,IAC/B,+BAA+B;AAAA,IAC/B,QAAU;AAAA,IACV,qBAAqB;AAAA,EACvB;AAAA,EACA,iBAAmB;AAAA,IACjB,mBAAmB;AAAA,IACnB,4BAA4B;AAAA,IAC5B,4BAA4B;AAAA,IAC5B,yBAAyB;AAAA,IACzB,eAAe;AAAA,IACf,iBAAiB;AAAA,IACjB,uBAAuB;AAAA,IACvB,cAAc;AAAA,IACd,QAAU;AAAA,IACV,OAAS;AAAA,IACT,MAAQ;AAAA,IACR,eAAe;AAAA,IACf,UAAY;AAAA,IACZ,oBAAoB;AAAA,IACpB,MAAQ;AAAA,IACR,KAAO;AAAA,IACP,YAAc;AAAA,IACd,QAAU;AAAA,EACZ;AAAA,EACA,kBAAoB;AAAA,IAClB,4BAA4B;AAAA,IAC5B,QAAU;AAAA,EACZ;AAAA,EACA,gBAAkB;AAAA,EAClB,SAAW;AAAA,IACT,MAAQ;AAAA,EACV;AAAA,EACA,OAAS;AAAA,IACP,MAAQ;AAAA,EACV;AAAA,EACA,eAAiB;AAAA,IACf,QAAU;AAAA,EACZ;AACF;;;AClIA,SAAS,gBAAgB;AAElB,SAAS,aAAsB;AACpC,MAAI;AACF,aAAS,gCAAgC;AACzC,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;;;ACTA,YAAY,OAAO;AACnB,SAAS,gBAAgB,iBAAiB,uBAAuB;AACjE,OAAO,YAAY;AACnB,SAAS,iBAAiB;AAC1B,OAAOC,WAAU;AACjB,OAAO,YAAY;;;ACLnB,SAAS,kBAAkB;AAC3B,SAAS,YAAAC,iBAAgB;AACzB,OAAO,UAAU;AAEV,IAAM,cAAc,MAAM;AAC/B,QAAM,kBAAkB,WAAW,cAAc;AAEjD,MAAI,oBAAoB,QAAW;AACjC,WAAO,KAAK,QAAQ,eAAe;AAAA,EACrC;AAEA,SAAO,QAAQ,IAAI;AACrB;AAEO,IAAM,UAAU,MAAM;AAC3B,MAAI;AACF,UAAM,gBAAgBA,UAAS,iCAAiC;AAAA,MAC9D,KAAK,YAAY;AAAA,IACnB,CAAC;AACD,WAAO,cAAc,SAAS,EAAE,KAAK;AAAA,EACvC,QAAQ;AACN,WAAO,YAAY;AAAA,EACrB;AACF;;;ACnBA,IAAI,cAAwC;AAErC,IAAM,KAAM,UAAU,eAA8C;AACzE,MAAI,gBAAgB,MAAM;AACxB,UAAM,EAAE,EAAE,IAAI,MAAM,OAAO,OAAO;AAClC,kBAAc,EAAE;AAAA,MACd,KAAK,YAAY;AAAA,IACnB,CAAC;AAAA,EACH;AACA,SAAO,YAAY,GAAG,UAAU;AAClC;;;ACdA,OAAO,mBAAmB;AAEnB,IAAM,mBAAmB,CAAI,cAAsC;AACxE,MAAI,cAAc,GAAG;AACnB,WAAO,UAAU;AAAA,EACnB;AAEA,SAAO;AACT;;;AHGO,IAAM,cAAN,MAAkB;AAAA,EAChB,OAAoD;AAAA,EAE3D,MAAM,OAAO;AACX,UAAM,OAAO,MAAM,gBAAgB,YAAY,CAAC;AAEhD,QAAI,SAAS,MAAM;AACjB,MAAE;AAAA,QACA;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,SAAK,OAAO;AAAA,EACd;AAAA,EAEA,WAAW,UAAkB;AAC3B,WAAO,gBAAgB,QAAQ;AAAA,EACjC;AAAA,EAEA,MAAM,cAAc,UAAkB,SAAiB;AACrD,UAAM,KAAK,KAAK;AAEhB,WAAO,GAAG,KAAK,SAAS,IAAI;AAE5B,UAAM,cAAc,MAAM,eAAe,QAAQ;AAEjD,QAAI,aAAa,YAAY,QAAW;AACtC,aAAO;AAAA,IACT;AAEA,WAAO,OAAO,UAAU,YAAY,SAAS,OAAO;AAAA,EACtD;AAAA,EAEA,MAAM,QAAQ;AACZ,UAAM,KAAK,KAAK;AAEhB,WAAO,GAAG,KAAK,SAAS,IAAI;AAE5B,WAAO,KAAK,KAAK,SAAS;AAAA,EAC5B;AAAA,EAEA,MAAM,YAAY;AAChB,QAAI,MAAM,KAAK,MAAM,GAAG;AACtB;AAAA,IACF;AAEA,WAAO,GAAG,KAAK,SAAS,IAAI;AAE5B,SAAK,KAAK,OAAO;AAEjB,UAAM,KAAK,KAAK;AAAA,EAClB;AAAA,EAEA,MAAM,iBAAiB;AACrB,UAAM,WAAW,MAAM,gBAAgB,gBAAgB;AACvD,UAAM,UAAU,MAAM,gBAAgB,OAAO;AAC7C,UAAM,WAAW,MAAM,gBAAgB,cAAc;AACrD,QAAI,WAAW,UAAU;AACvB,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAEA,QAAI,UAAU;AACZ,aAAO;AAAA,IACT;AAEA,QAAI,UAAU;AACZ,aAAO;AAAA,IACT;AAEA,QAAI,SAAS;AACX,aAAO;AAAA,IACT;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO;AACX,UAAM;AAAA,MACJC,MAAK,KAAK,YAAY,GAAG,cAAc;AAAA,MACvC,KAAK,UAAU,KAAK,MAAM,MAAM,CAAC;AAAA,IACnC;AAAA,EACF;AAAA,EAEA,MAAM,qBAAqB,MAAc,QAAgB;AACvD,UAAM,KAAK,KAAK;AAEhB,WAAO,GAAG,KAAK,SAAS,IAAI;AAE5B,QAAI,KAAK,KAAK,UAAU,IAAI,MAAM,QAAW;AAC3C;AAAA,IACF;AAEA,SAAK,KAAK,UAAU,KAAK,KAAK,WAAW,CAAC;AAC1C,SAAK,KAAK,QAAQ,IAAI,IAAI;AAE1B,UAAM,KAAK,KAAK;AAAA,EAClB;AAAA,EAEA,MAAM,QACJ,UACAC,UACA;AACA,UAAM,cAAc,MAAM,KAAK,WAAW,QAAQ;AAElD,QAAI,CAAC,aAAa;AAChB,YAAMC,WAAY,UAAQ;AAC1B,uBAAiB,MAAM;AACrB,QAAAA,SAAQ,MAAM,gBAAgB,QAAQ,EAAE;AAAA,MAC1C,CAAC;AAED,YAAM,WAAWD,UAAS,QAAQ,OAAO,OAAO,EAAE,IAAI,QAAQ;AAC9D,uBAAiB,MAAM;AACrB,QAAAC,SAAQ,KAAK,GAAG,QAAQ,0BAAmB;AAAA,MAC7C,CAAC;AAED,YAAM,KAAK,KAAK;AAEhB;AAAA,IACF;AAEA,UAAM,OAAO,MAAM,eAAe,QAAQ;AAE1C,QACG,MAAM,YAAY,UACjBD,UAAS,eAAe,UACxB,CAAC,OAAO,UAAU,KAAK,SAASA,SAAQ,UAAU,KACpDA,UAAS,iBAAiB,MAC1B;AACA,YAAMC,WAAY,UAAQ;AAC1B,uBAAiB,MAAM;AACrB,QAAAA,SAAQ,MAAM,kBAAkB,QAAQ,EAAE;AAAA,MAC5C,CAAC;AACD,YAAM,WAAWD,SAAQ,QAAQ,OAAO,OAAO,EAAE,IAAI,QAAQ;AAC7D,uBAAiB,MAAM;AACrB,QAAAC,SAAQ,KAAK,GAAG,QAAQ,2BAAoB;AAAA,MAC9C,CAAC;AAED,YAAM,KAAK,KAAK;AAAA,IAClB;AAAA,EACF;AAAA,EAEA,MAAM,eAAe;AACnB,UAAM;AAAA,EACR;AACF;;;AI9JA,YAAYC,QAAO;AACnB,OAAOC,oBAAmB;AAEnB,IAAM,gBAAgB,OAAO,UAA4B;AAC9D,MAAI,CAACA,eAAc,GAAG;AACpB,WAAO;AAAA,EACT;AAEA,SAAS,WAAQ;AAAA,IACf,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,GAAG;AAAA,EACL,CAAC;AACH;;;ACbA,SAAS,aAAAC,kBAAiB;AAC1B,OAAOC,WAAU;;;ACDjB,OAAOC,aAAY;AAKnB,IAAM,cAAc,IAAI,YAAY;AAE7B,IAAM,eAAe,YAAY;AACtC,MAAI,CAAE,MAAM,YAAY,WAAW,OAAO,GAAI;AAC5C,UAAM,YAAY,QAAQ,SAAS,EAAE,KAAK,KAAK,CAAC;AAChD,UAAM;AAAA,EACR;AAEA,QAAM,YAAY,KAAK;AAEvB,EAAAC,QAAO,GAAG,YAAY,SAAS,IAAI;AAEnC,cAAY,KAAK,UAAU,YAAY,KAAK,WAAW,CAAC;AACxD,cAAY,KAAK,QAAQ,UAAU;AAEnC,QAAM,YAAY,KAAK;AACzB;;;ACrBO,IAAM,aAAa,MAAM;AAAA;AAAA;AAAA;;;AFQhC,IAAM,OAAO,YAAY;AAEzB,IAAMC,eAAc,IAAI,YAAY;AAE7B,IAAM,oBAAoB,YAAY;AAC3C,QAAM,aAAa;AAEnB,QAAMA,aAAY,QAAQ,mBAAmB,EAAE,KAAK,KAAK,CAAC;AAE1D,QAAMC;AAAA,IACJC,MAAK,KAAK,MAAM,mBAAmB;AAAA,IACnC;AAAA,EACF;AAEA,QAAMD,WAAUC,MAAK,KAAK,MAAM,kBAAkB,GAAG,WAAW,CAAC;AACnE;;;AGvBA,YAAYC,QAAO;AACnB,SAAS,kBAAkB;AAC3B,YAAY,QAAQ;AACpB,OAAOC,WAAU;AAMjB,IAAM,oBAAoB;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEA,IAAMC,eAAc,IAAI,YAAY;AAE7B,IAAM,gBAAgB,OAAOC,oBAAmB,UAAU;AAC/D,QAAMC,QAAO,YAAY;AAEzB,QAAMF,aAAY,KAAK;AAEvB,QAAMA,aAAY,QAAQ,UAAU,EAAE,KAAK,MAAM,YAAY,MAAM,CAAC;AAEpE,QAAM,OAAO,MAAMA,aAAY,eAAe;AAE9C,MAAI,SAAS,WAAY,MAAMA,aAAY,WAAW,MAAM,GAAI;AAC9D,UAAM,OAAO,MAAMA,aAAY,cAAc,QAAQ,MAAM;AAE3D,QAAI,CAAC,MAAM;AACT,MAAE;AAAA,QACA;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,UAAMA,aAAY,QAAQ,4BAA4B,EAAE,KAAK,KAAK,CAAC;AAAA,EACrE;AAEA,QAAM,eAAe,kBAAkB;AAAA,IAAK,CAAC,eAC3C,WAAWG,MAAK,KAAKD,OAAM,UAAU,CAAC;AAAA,EACxC;AAEA,MAAI,iBAAiB,QAAW;AAC9B,UAAM,gBAAgB,MAAS;AAAA,MAC7BC,MAAK,KAAKD,OAAM,YAAY;AAAA,MAC5B;AAAA,IACF;AAEA,QAAI,cAAc,SAAS,wBAAwB,GAAG;AACpD,MAAE,QAAK,+CAA0C;AAEjD;AAAA,IACF,OAAO;AACL,UAAID,mBAAkB;AAEpB,cAAS,MAAGE,MAAK,KAAKD,OAAM,YAAY,CAAC;AAAA,MAC3C,OAAO;AACL,cAAM,cAAc,MAAM,cAAc;AAAA,UACtC,SAAS;AAAA,QACX,CAAC;AAED,YAAM,YAAS,WAAW,KAAK,CAAC,aAAa;AAC3C,UAAE,UAAO,2DAAwD;AACjE,kBAAQ,KAAK,CAAC;AAAA,QAChB;AAEA,cAAS,MAAGC,MAAK,KAAKD,OAAM,YAAY,CAAC;AAAA,MAC3C;AAAA,IACF;AAAA,EACF;AAEA,QAAM,QAAQ,MAAMF,aAAY,MAAM;AAEtC,QAAM,iBAAiB,QAAQ,qBAAqB;AAEpD,QAAS;AAAA,IACPG,MAAK,KAAKD,OAAM,cAAc;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,EAIF;AAEA,EAAE,QAAK,mDAA8C;AACvD;;;AC9FA,YAAYE,QAAO;AACnB,SAAS,cAAAC,mBAAkB;AAC3B,YAAYC,SAAQ;AACpB,OAAOC,WAAU;;;ACHV,IAAM,eAAe,MAAM;AAAA;AAAA;AAAA;AAAA;;;ACE3B,IAAM,WAAW,CAAC;AAAA,EACvB;AAAA,EACA;AACF,MAGM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAmBoB,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUnC,iBAAiB,aAAa,IAAI,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACrC/B,IAAM,qBAAqB,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAjC,IAAM,aAAa,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEzB,IAAM,WAAW,CAAC;AAAA,EACvB;AAAA,EACA;AACF,MAGM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAmBoB,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA,EAKnC,iBAAiB,aAAa,IAAI,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;AC9B/B,IAAM,UAAU,CAAC;AAAA,EACtB;AAAA,EACA;AACF,MAGM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAmBoB,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA,EAKnC,iBAAiB,aAAa,IAAI,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ANnBtC,IAAMC,eAAc,IAAI,YAAY;AAE7B,IAAM,uBAAuB,YAAY;AAC9C,QAAM,eAAe,QAAQ;AAC7B,QAAM,mBAAmB,YAAY;AACrC,QAAMA,aAAY,KAAK;AAEvB,QAAM,uBAAuBC,MAAK,KAAK,cAAc,mBAAmB;AACxE,QAAS,UAAM,sBAAsB,EAAE,WAAW,KAAK,CAAC;AAExD,QAAM,OAAO,MAAMD,aAAY,eAAe;AAE9C,QAAM,iBAAiB,MAAMA,aAAY,WAAW,iBAAiB;AAErE,MAAI,SAAS,UAAU;AACrB,QAAI,CAACE,YAAWD,MAAK,KAAK,kBAAkB,cAAc,CAAC,GAAG;AAC5D,MAAE;AAAA,QACA;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,UAAS;AAAA,MACPA,MAAK,KAAK,sBAAsB,QAAQ;AAAA,MACxC,SAAS;AAAA,QACP,aAAa;AAAA,QACb;AAAA,MACF,CAAC;AAAA,IACH;AAEA,UAAS;AAAA,MACPA,MAAK,KAAK,sBAAsB,QAAQ;AAAA,MACxC,mBAAmB;AAAA,IACrB;AAAA,EACF;AAEA,MAAI,SAAS,SAAS;AACpB,UAAS;AAAA,MACPA,MAAK,KAAK,sBAAsB,QAAQ;AAAA,MACxC,QAAQ;AAAA,QACN,aAAa;AAAA,QACb;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAEA,MAAI,SAAS,UAAU;AACrB,UAAS;AAAA,MACPA,MAAK,KAAK,sBAAsB,QAAQ;AAAA,MACxC,SAAS;AAAA,QACP,aAAa;AAAA,QACb;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAEA,MAAI,CAACC,YAAWD,MAAK,KAAK,cAAc,wBAAwB,CAAC,GAAG;AAClE,UAAS;AAAA,MACPA,MAAK,KAAK,cAAc,wBAAwB;AAAA,MAChD,WAAW;AAAA,IACb;AAAA,EACF;AAEA,QAAMD,aAAY,qBAAqB,gBAAgB,oBAAoB;AAC3E,QAAMA,aAAY,qBAAqB,QAAQ,2BAA2B;AAC1E,QAAMA,aAAY,qBAAqB,UAAU,oBAAoB;AACrE,QAAMA,aAAY,qBAAqB,aAAa,cAAc;AAElE,EAAE,QAAK,wCAAmC;AAC5C;;;AOlFA,OAAOG,aAAY;AACnB,SAAS,aAAAC,kBAAiB;AAK1B,IAAMC,eAAc,IAAI,YAAY;AAE7B,IAAM,oBAAoB,YAAY;AAC3C,QAAMA,aAAY,KAAK;AAEvB,EAAAC,QAAO,GAAGD,aAAY,SAAS,IAAI;AAEnC,QAAM,aAAa;AAEnB,QAAMA,aAAY,QAAQ,eAAe,EAAE,KAAK,KAAK,CAAC;AAEtD,QAAME,WAAU,qBAAqB,mBAAmB;AAExD,EAAAF,aAAY,KAAK,aAAa,IAAI;AAAA,IAChC,KAAK;AAAA,EACP;AAEA,QAAMA,aAAY,KAAK;AACzB;;;ACxBA,YAAYG,QAAO;AACnB,OAAOC,aAAY;AACnB,SAAS,cAAAC,mBAAkB;AAC3B,YAAYC,SAAQ;AACpB,OAAOC,WAAU;AAMjB,IAAM,sBAAsB;AAAA,EAC1B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEA,IAAMC,eAAc,IAAI,YAAY;AAE7B,IAAM,kBAAkB,OAAOC,oBAAmB,UAAU;AACjE,QAAMC,QAAO,YAAY;AAEzB,QAAMF,aAAY,KAAK;AACvB,EAAAG,QAAO,GAAGH,aAAY,SAAS,IAAI;AAEnC,QAAMA,aAAY,QAAQ,YAAY,EAAE,KAAK,MAAM,YAAY,MAAM,CAAC;AAEtE,QAAM,iBAAiB,oBAAoB;AAAA,IAAK,CAAC,eAC/CI,YAAWC,MAAK,KAAKH,OAAM,UAAU,CAAC;AAAA,EACxC;AAEA,QAAM,qBAAqB;AAE3B,MAAI,mBAAmB,UAAaF,aAAY,KAAK,aAAa,QAAW;AAC3E,QAAIA,aAAY,KAAK,aAAa,oBAAoB;AACpD,MAAE,QAAK,0DAAqD;AAC5D;AAAA,IACF;AAEA,QAAIC,mBAAkB;AAEpB,iBAAW,cAAc,qBAAqB;AAC5C,cAAS,OAAGI,MAAK,KAAKH,OAAM,UAAU,CAAC,EAAE,MAAM,MAAM,IAAI;AAAA,MAC3D;AAAA,IACF,OAAO;AACL,YAAM,cAAc,MAAM,cAAc;AAAA,QACtC,SAAS;AAAA,MACX,CAAC;AAED,UAAM,YAAS,WAAW,KAAK,CAAC,aAAa;AAC3C,QAAE,UAAO,yDAAiD;AAC1D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,iBAAW,cAAc,qBAAqB;AAC5C,cAAS,OAAGG,MAAK,KAAKH,OAAM,UAAU,CAAC,EAAE,MAAM,MAAM,IAAI;AAAA,MAC3D;AAAA,IACF;AAAA,EACF;AAEA,EAAAF,aAAY,KAAK,WAAW;AAE5B,QAAMA,aAAY,KAAK;AAEvB,EAAE,QAAK,6CAAwC;AACjD;;;ApB/CA,IAAM,UAAU,IAAI,QAAQ;AAC5B,QACG,KAAK,gBAAgB,EACrB,YAAY,wCAAwC,EACpD,QAAQ,gBAAgB,OAAO,EAC/B,OAAO,eAAe,wBAAwB,KAAK,EACnD,OAAO,YAAY,gCAAgC,KAAK,EACxD,OAAO,cAAc,kCAAkC,KAAK,EAC5D,OAAO,eAAe,0BAA0B,KAAK,EACrD,OAAO,gBAAgB,oCAAoC,KAAK,EAChE,OAAO,aAAa,qBAAqB,KAAK;AAEjD,QAAQ,MAAM;AACd,IAAM,UAAsB,QAAQ,KAAK;AAGzC,IAAM,mBAAmB,QAAQ,KAAK,SAAS;AAE/C,eAAe,OAAO;AACpB,MAAI,CAAC,kBAAkB;AACrB,IAAE,SAAM,EAAE,KAAK,EAAE,OAAO,oBAAoB,CAAC,CAAC;AAAA,EAChD;AAEA,QAAM,YAAY,aAAa;AAE/B,MAAI,cAAc,OAAO;AACvB,UAAM,iBAAiB,aAAa;AACpC,UAAM,iBAAiB;AAAA,EACzB,EAAE,IAAI,EAAE,KAAK,mCAAoB,cAAc,yCAA0B,CAAC,CAAC;AAAA;AAAA,2CAE1C,EAAE,OAAO,cAAc,CAAC,+CAA0C,EAAE,OAAO,QAAQ,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,EAKrH,EAAE,KAAK,oBAAoB,CAAC;AAE1B,QAAI,kBAAkB;AACpB,cAAQ,MAAM,cAAc;AAAA,IAC9B,OAAO;AACL,MAAE,UAAO,cAAc;AAAA,IACzB;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AAGA,MAAI,QAAQ,UAAU,QAAQ,CAAC,WAAW,GAAG;AAC3C,QAAI,kBAAkB;AACpB,cAAQ;AAAA,QACN;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,UAAM,cAAc,MAAM,cAAc;AAAA,MACtC,SAAS;AAAA,IACX,CAAC;AAED,QAAM,YAAS,WAAW,KAAK,CAAC,aAAa;AAC3C,MAAE,UAAO,4CAAyC;AAClD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF;AAEA,QAAMM,eAAc,IAAI,YAAY;AAGpC,QAAM,cAAc,MAAMA,aAAY,eAAe;AAGrD,MAAI,CAAC,kBAAkB;AACrB,QAAI,gBAAgB,UAAU;AAC5B,YAAM,cAAc,MAAM,cAAc;AAAA,QACtC,SAAS;AAAA,MACX,CAAC;AAED,UAAM,YAAS,WAAW,KAAK,CAAC,aAAa;AAC3C,QAAE,UAAO,6EAAmD;AAC5D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAAA,IACF;AAEA,QAAI,gBAAgB,SAAS;AAC3B,YAAM,cAAc,MAAM,cAAc;AAAA,QACtC,SAAS;AAAA,MACX,CAAC;AAED,UAAM,YAAS,WAAW,GAAG;AAC3B,QAAE,UAAO,WAAI;AACb,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,UAAI,CAAC,aAAa;AAChB,QAAE,UAAO,6EAAmD;AAC5D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAAA,IACF;AAEA,QAAI,gBAAgB,UAAU;AAC5B,YAAM,cAAc,MAAM,cAAc;AAAA,QACtC,SAAS;AAAA,MACX,CAAC;AAED,UAAM,YAAS,WAAW,GAAG;AAC3B,QAAE,UAAO,WAAI;AACb,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAAA,IACF;AAEA,QAAI,gBAAgB,QAAQ;AAC1B,MAAE;AAAA,QACA;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF;AACA,MAAI,gBAAgB,YAAY,gBAAgB,SAAS;AACvD,QAAI,kBAAkB;AACpB,YAAMA,aAAY,UAAU;AAAA,IAC9B,OAAO;AACL,UAAI,CAAE,MAAMA,aAAY,MAAM,GAAI;AAChC,cAAM,cAAc,MAAM,cAAc;AAAA,UACtC,SAAS;AAAA,QACX,CAAC;AAED,YAAM,YAAS,WAAW,KAAK,CAAC,aAAa;AAC3C,UAAE,UAAO,kDAA0C;AACnD,kBAAQ,KAAK,CAAC;AAAA,QAChB;AAEA,cAAMA,aAAY,UAAU;AAAA,MAC9B;AAAA,IACF;AAAA,EACF;AAGA,MAAI,iBAA2B,CAAC;AAEhC,MAAI,QAAQ,QAAQ,MAAM;AACxB,qBAAiB,CAAC,UAAU,YAAY,aAAa,YAAY;AAAA,EACnE,WAAW,kBAAkB;AAE3B,QAAI,QAAQ,WAAW,MAAM;AAC3B,qBAAe,KAAK,QAAQ;AAAA,IAC9B;AACA,QAAI,QAAQ,aAAa,MAAM;AAC7B,qBAAe,KAAK,UAAU;AAAA,IAChC;AACA,QAAI,QAAQ,aAAa,MAAM;AAC7B,qBAAe,KAAK,WAAW;AAAA,IACjC;AACA,QAAI,QAAQ,eAAe,MAAM;AAC/B,qBAAe,KAAK,YAAY;AAAA,IAClC;AAEA,QAAI,eAAe,WAAW,GAAG;AAC/B,cAAQ;AAAA,QACN;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,OAAO;AAEL,UAAM,kBAAkB,MAAQ,eAAY;AAAA,MAC1C,SAAS,6CAAgC,EAAE,KAAK,6CAAmC,CAAC;AAAA,MACpF,eAAe,CAAC,UAAU,YAAY,aAAa,YAAY;AAAA,MAC/D,SAAS;AAAA,QACP;AAAA,UACE,OAAO;AAAA,UACP,OAAO,EAAE,KAAK,EAAE,WAAW,QAAQ,CAAC;AAAA,UACpC,MAAM;AAAA,QACR;AAAA,QACA;AAAA,UACE,OAAO;AAAA,UACP,OAAO,EAAE,KAAK,EAAE,aAAa,UAAU,CAAC;AAAA,UACxC,MAAM;AAAA,QACR;AAAA,QACA;AAAA,UACE,OAAO;AAAA,UACP,OAAO,EAAE,KAAK,gBAAgB;AAAA,UAC9B,MAAM;AAAA,QACR;AAAA,QACA;AAAA,UACE,OAAO;AAAA,UACP,OAAO,EAAE,KAAK,YAAY;AAAA,UAC1B,MAAM;AAAA,QACR;AAAA,MACF;AAAA,MACA,UAAU;AAAA,IACZ,CAAC;AAED,QAAM,YAAS,eAAe,KAAK,gBAAgB,WAAW,GAAG;AAC/D,MAAE,UAAO,yCAA+B;AACxC,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,qBAAiB;AAAA,EACnB;AAGA,QAAMA,aAAY,QAAQ,kBAAkB;AAAA,IAC1C,KAAK;AAAA,IACL,cAAc,CAAC;AAAA,EACjB,CAAC;AAGD,MAAI,eAAe,SAAS,QAAQ,GAAG;AACrC,UAAM,cAAc,gBAAgB;AAAA,EACtC;AAEA,MAAI,eAAe,SAAS,UAAU,GAAG;AACvC,UAAM,gBAAgB,gBAAgB;AACtC,UAAM,kBAAkB;AAAA,EAC1B;AAEA,MAAI,eAAe,SAAS,YAAY,GAAG;AACzC,UAAM,kBAAkB;AAAA,EAC1B;AAEA,MAAI,eAAe,SAAS,WAAW,GAAG;AACxC,UAAM,qBAAqB;AAAA,EAC7B;AAEA,QAAMA,aAAY,aAAa;AAE/B,MAAI,kBAAkB;AACpB,YAAQ,IAAI,qDAAsC;AAAA,EACpD,OAAO;AACL,IAAE,SAAM,qDAAsC;AAAA,EAChD;AACF;AAGA,IAAI;AACF,QAAM,KAAK;AACb,SAAS,OAAgB;AACvB,UAAQ,MAAM,sCAAkB,KAAK;AACrC,UAAQ,KAAK,CAAC;AAChB;","names":["p","path","execSync","path","options","spinner","p","isInteractive","writeFile","path","assert","assert","packageJson","writeFile","path","p","path","packageJson","isNonInteractive","root","path","p","existsSync","fs","path","packageJson","path","existsSync","assert","writeFile","packageJson","assert","writeFile","p","assert","existsSync","fs","path","packageJson","isNonInteractive","root","assert","existsSync","path","packageJson"]}
@@ -1,9 +1,4 @@
1
- import {
2
- init_esm_shims
3
- } from "../chunk-J5OUMHDO.js";
4
-
5
1
  // src/commitlint/index.ts
6
- init_esm_shims();
7
2
  var config = {
8
3
  extends: ["@commitlint/config-conventional"],
9
4
  helpUrl: "https://docs.solvro.pl/github#nazewnictwo-commit%C3%B3w",
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/commitlint/index.ts"],"sourcesContent":["import type { UserConfig } from \"@commitlint/types\";\n\nconst config: UserConfig = {\n extends: [\"@commitlint/config-conventional\"],\n helpUrl: \"https://docs.solvro.pl/github#nazewnictwo-commit%C3%B3w\",\n rules: {\n \"type-enum\": [\n 2,\n \"always\",\n [\n // A new feature\n \"feat\",\n //A bug fix\n \"fix\",\n // A code change that neither fixes a bug nor adds a feature\n \"refactor\",\n // Boring changes\n \"chore\",\n // Documentation-only changes\n \"docs\",\n // Changes to CI workflows\n \"ci\",\n // Adding missing tests or correcting existing tests\n \"test\",\n \"build\",\n \"release\",\n ],\n ],\n\n // @ts-expect-error ???\n \"body-max-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"body-max-line-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"footer-max-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"footer-max-line-length\": [0, \"always\"],\n },\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default config;\n"],"mappings":";;;;;AAAA;AAEA,IAAM,SAAqB;AAAA,EACzB,SAAS,CAAC,iCAAiC;AAAA,EAC3C,SAAS;AAAA,EACT,OAAO;AAAA,IACL,aAAa;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA;AAAA,QAEE;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IACF;AAAA;AAAA,IAGA,mBAAmB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAE/B,wBAAwB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAEpC,qBAAqB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAEjC,0BAA0B,CAAC,GAAG,QAAQ;AAAA,EACxC;AACF;AAGA,IAAO,qBAAQ;","names":[]}
1
+ {"version":3,"sources":["../../src/commitlint/index.ts"],"sourcesContent":["import type { UserConfig } from \"@commitlint/types\";\n\nconst config: UserConfig = {\n extends: [\"@commitlint/config-conventional\"],\n helpUrl: \"https://docs.solvro.pl/github#nazewnictwo-commit%C3%B3w\",\n rules: {\n \"type-enum\": [\n 2,\n \"always\",\n [\n // A new feature\n \"feat\",\n //A bug fix\n \"fix\",\n // A code change that neither fixes a bug nor adds a feature\n \"refactor\",\n // Boring changes\n \"chore\",\n // Documentation-only changes\n \"docs\",\n // Changes to CI workflows\n \"ci\",\n // Adding missing tests or correcting existing tests\n \"test\",\n \"build\",\n \"release\",\n ],\n ],\n\n // @ts-expect-error ???\n \"body-max-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"body-max-line-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"footer-max-length\": [0, \"always\"],\n // @ts-expect-error ???\n \"footer-max-line-length\": [0, \"always\"],\n },\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default config;\n"],"mappings":";AAEA,IAAM,SAAqB;AAAA,EACzB,SAAS,CAAC,iCAAiC;AAAA,EAC3C,SAAS;AAAA,EACT,OAAO;AAAA,IACL,aAAa;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA;AAAA,QAEE;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA;AAAA,QAEA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IACF;AAAA;AAAA,IAGA,mBAAmB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAE/B,wBAAwB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAEpC,qBAAqB,CAAC,GAAG,QAAQ;AAAA;AAAA,IAEjC,0BAA0B,CAAC,GAAG,QAAQ;AAAA,EACxC;AACF;AAGA,IAAO,qBAAQ;","names":[]}
@@ -2,153 +2,18 @@ import {
2
2
  default as default2,
3
3
  default2 as default3,
4
4
  default6 as default4
5
- } from "../chunk-HM3MY7J3.js";
6
- import {
7
- init_esm_shims
8
- } from "../chunk-J5OUMHDO.js";
5
+ } from "../chunk-VMUJRX4H.js";
9
6
 
10
7
  // src/eslint/index.ts
11
- init_esm_shims();
12
- import { findUpSync as findUpSync2 } from "find-up-simple";
8
+ import { findUpSync } from "find-up-simple";
13
9
  import { isPackageListed } from "local-pkg";
14
- import path3 from "path";
10
+ import path from "path";
15
11
  import tseslint3 from "typescript-eslint";
16
12
 
17
13
  // src/eslint/presets/base.ts
18
- init_esm_shims();
19
-
20
- // node_modules/eslint-config-flat-gitignore/dist/index.mjs
21
- init_esm_shims();
22
- import fs2 from "fs";
23
- import path2, { join, resolve, relative, dirname } from "path";
24
- import process2 from "process";
25
-
26
- // node_modules/@eslint/compat/dist/esm/index.js
27
- init_esm_shims();
28
- import fs from "fs";
29
- import path from "path";
30
- function convertIgnorePatternToMinimatch(pattern) {
31
- const isNegated = pattern.startsWith("!");
32
- const negatedPrefix = isNegated ? "!" : "";
33
- const patternToTest = (isNegated ? pattern.slice(1) : pattern).trimEnd();
34
- if (["", "**", "/**", "**/"].includes(patternToTest)) {
35
- return `${negatedPrefix}${patternToTest}`;
36
- }
37
- const firstIndexOfSlash = patternToTest.indexOf("/");
38
- const matchEverywherePrefix = firstIndexOfSlash < 0 || firstIndexOfSlash === patternToTest.length - 1 ? "**/" : "";
39
- const patternWithoutLeadingSlash = firstIndexOfSlash === 0 ? patternToTest.slice(1) : patternToTest;
40
- const escapedPatternWithoutLeadingSlash = patternWithoutLeadingSlash.replaceAll(
41
- /(?=((?:\\.|[^{(])*))\1([{(])/guy,
42
- "$1\\$2"
43
- );
44
- const matchInsideSuffix = patternToTest.endsWith("/**") ? "/*" : "";
45
- return `${negatedPrefix}${matchEverywherePrefix}${escapedPatternWithoutLeadingSlash}${matchInsideSuffix}`;
46
- }
47
-
48
- // node_modules/eslint-config-flat-gitignore/dist/index.mjs
49
- import "fs/promises";
50
- import { fileURLToPath } from "url";
51
- function toArray(array) {
52
- array = array ?? [];
53
- return Array.isArray(array) ? array : [array];
54
- }
55
- var toPath = (urlOrPath) => urlOrPath instanceof URL ? fileURLToPath(urlOrPath) : urlOrPath;
56
- function findUpSync(name, {
57
- cwd = process2.cwd(),
58
- type = "file",
59
- stopAt
60
- } = {}) {
61
- let directory = path2.resolve(toPath(cwd) ?? "");
62
- const { root } = path2.parse(directory);
63
- stopAt = path2.resolve(directory, toPath(stopAt) ?? root);
64
- while (directory && directory !== stopAt && directory !== root) {
65
- const filePath = path2.isAbsolute(name) ? name : path2.join(directory, name);
66
- try {
67
- const stats = fs2.statSync(filePath, { throwIfNoEntry: false });
68
- if (type === "file" && stats?.isFile() || type === "directory" && stats?.isDirectory()) {
69
- return filePath;
70
- }
71
- } catch {
72
- }
73
- directory = path2.dirname(directory);
74
- }
75
- }
76
- var GITIGNORE = ".gitignore";
77
- var GITMODULES = ".gitmodules";
78
- function ignore(options = {}) {
79
- const ignores2 = [];
80
- const {
81
- cwd = process2.cwd(),
82
- root = false,
83
- files: _files = root ? GITIGNORE : findUpSync(GITIGNORE, { cwd }) || [],
84
- filesGitModules: _filesGitModules = root ? fs2.existsSync(join(cwd, GITMODULES)) ? GITMODULES : [] : findUpSync(GITMODULES, { cwd }) || [],
85
- strict = true
86
- } = options;
87
- const files = toArray(_files).map((file) => resolve(cwd, file));
88
- const filesGitModules = toArray(_filesGitModules).map((file) => resolve(cwd, file));
89
- for (const file of files) {
90
- let content = "";
91
- try {
92
- content = fs2.readFileSync(file, "utf8");
93
- } catch (error) {
94
- if (strict)
95
- throw error;
96
- continue;
97
- }
98
- const relativePath = relative(cwd, dirname(file)).replaceAll("\\", "/");
99
- const globs = content.split(/\r?\n/u).filter((line) => line && !line.startsWith("#")).map((line) => convertIgnorePatternToMinimatch(line)).map((glob) => relativeMinimatch(glob, relativePath, cwd)).filter((glob) => glob !== null);
100
- ignores2.push(...globs);
101
- }
102
- for (const file of filesGitModules) {
103
- let content = "";
104
- try {
105
- content = fs2.readFileSync(file, "utf8");
106
- } catch (error) {
107
- if (strict)
108
- throw error;
109
- continue;
110
- }
111
- const dirs = parseGitSubmodules(content);
112
- ignores2.push(...dirs.map((dir) => `${dir}/**`));
113
- }
114
- if (strict && files.length === 0)
115
- throw new Error("No .gitignore file found");
116
- return {
117
- name: options.name || "gitignore",
118
- ignores: ignores2
119
- };
120
- }
121
- function relativeMinimatch(pattern, relativePath, cwd) {
122
- if (["", ".", "/"].includes(relativePath))
123
- return pattern;
124
- const negated = pattern.startsWith("!") ? "!" : "";
125
- let cleanPattern = negated ? pattern.slice(1) : pattern;
126
- if (!relativePath.endsWith("/"))
127
- relativePath = `${relativePath}/`;
128
- const isParent = relativePath.startsWith("..");
129
- if (!isParent)
130
- return `${negated}${relativePath}${cleanPattern}`;
131
- if (!relativePath.match(/^(\.\.\/)+$/))
132
- throw new Error("The ignore file location should be either a parent or child directory");
133
- if (cleanPattern.startsWith("**"))
134
- return pattern;
135
- const parents = relative(resolve(cwd, relativePath), cwd).split(/[/\\]/);
136
- while (parents.length && cleanPattern.startsWith(`${parents[0]}/`)) {
137
- cleanPattern = cleanPattern.slice(parents[0].length + 1);
138
- parents.shift();
139
- }
140
- if (cleanPattern.startsWith("**"))
141
- return `${negated}${cleanPattern}`;
142
- if (parents.length === 0)
143
- return `${negated}${cleanPattern}`;
144
- return null;
145
- }
146
- function parseGitSubmodules(content) {
147
- return content.split(/\r?\n/u).map((line) => line.match(/path\s*=\s*(.+)/u)).filter((match) => match !== null).map((match) => match[1].trim());
148
- }
14
+ import gitignore from "eslint-config-flat-gitignore";
149
15
 
150
16
  // src/eslint/configs/comments.ts
151
- init_esm_shims();
152
17
  function comments() {
153
18
  return [
154
19
  {
@@ -168,11 +33,9 @@ function comments() {
168
33
  }
169
34
 
170
35
  // src/eslint/configs/disables.ts
171
- init_esm_shims();
172
36
  import tseslint from "typescript-eslint";
173
37
 
174
38
  // src/eslint/globs.ts
175
- init_esm_shims();
176
39
  var GLOB_SRC_EXT = "?([cm])[jt]s?(x)";
177
40
  var GLOB_SRC = "**/*.?([cm])[jt]s?(x)";
178
41
  var GLOB_JS = "**/*.?([cm])js";
@@ -278,7 +141,6 @@ function disables() {
278
141
  }
279
142
 
280
143
  // src/eslint/configs/formatters.ts
281
- init_esm_shims();
282
144
  import prettierConfig from "eslint-config-prettier";
283
145
  function formatters() {
284
146
  return [
@@ -293,7 +155,6 @@ function formatters() {
293
155
  }
294
156
 
295
157
  // src/eslint/configs/ignores.ts
296
- init_esm_shims();
297
158
  function ignores() {
298
159
  return [
299
160
  {
@@ -304,7 +165,6 @@ function ignores() {
304
165
  }
305
166
 
306
167
  // src/eslint/configs/javascript.ts
307
- init_esm_shims();
308
168
  import eslint from "@eslint/js";
309
169
  import globals from "globals";
310
170
  function javascript() {
@@ -528,7 +388,6 @@ function javascript() {
528
388
  }
529
389
 
530
390
  // src/eslint/configs/jsdoc.ts
531
- init_esm_shims();
532
391
  import jsdocPlugin from "eslint-plugin-jsdoc";
533
392
  function jsdoc() {
534
393
  return [
@@ -559,7 +418,6 @@ function jsdoc() {
559
418
  }
560
419
 
561
420
  // src/eslint/configs/typescript-relaxed.ts
562
- init_esm_shims();
563
421
  import tseslint2 from "typescript-eslint";
564
422
  function typescriptRelaxed() {
565
423
  return [
@@ -606,7 +464,7 @@ function typescriptRelaxed() {
606
464
 
607
465
  // src/eslint/presets/base.ts
608
466
  var basePreset = () => [
609
- ignore(),
467
+ gitignore(),
610
468
  ...javascript(),
611
469
  ...jsdoc(),
612
470
  ...comments(),
@@ -629,25 +487,25 @@ var solvro = async (...overrides) => {
629
487
  const configs = basePreset();
630
488
  const projectConfigs = [];
631
489
  if (isAdonis) {
632
- const { adonisPreset } = await import("../adonis-MGLA5SOL.js");
490
+ const { adonisPreset } = await import("../adonis-GN4AQKAU.js");
633
491
  projectConfigs.push(...adonisPreset());
634
492
  } else if (isNestJs) {
635
- const { nestjsPreset } = await import("../nestjs-33SQ4ZD2.js");
493
+ const { nestjsPreset } = await import("../nestjs-SVXAEFXN.js");
636
494
  projectConfigs.push(...await nestjsPreset());
637
495
  } else if (isReact) {
638
- const { reactPreset } = await import("../react-PWJWWBLW.js");
496
+ const { reactPreset } = await import("../react-CM27K2YV.js");
639
497
  projectConfigs.push(...await reactPreset());
640
498
  } else {
641
- const { nodePreset } = await import("../node-RC2VAG45.js");
499
+ const { nodePreset } = await import("../node-LOZFNKBL.js");
642
500
  projectConfigs.push(...nodePreset());
643
501
  }
644
- const tsConfigPath = findUpSync2("tsconfig.json", {
502
+ const tsConfigPath = findUpSync("tsconfig.json", {
645
503
  cwd: process.cwd()
646
504
  });
647
505
  if (tsConfigPath == null) {
648
506
  throw new Error("No tsconfig.json found");
649
507
  }
650
- const rootDirectory = path3.dirname(tsConfigPath);
508
+ const rootDirectory = path.dirname(tsConfigPath);
651
509
  const tsConfig = {
652
510
  languageOptions: {
653
511
  parserOptions: {