From 9a84f4a5e20cea925310ac7683c99f8b32d46a28 Mon Sep 17 00:00:00 2001 From: Jordan Shatford Date: Fri, 22 Mar 2024 10:39:40 +1100 Subject: [PATCH] feat: warn user about missing required dependencies in generated client --- src/index.ts | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/src/index.ts b/src/index.ts index ea03e0ea4..86ca16574 100644 --- a/src/index.ts +++ b/src/index.ts @@ -18,6 +18,15 @@ type Dependencies = Record; // TODO: add support for `openapi-ts.config.ts` const configFiles = ['openapi-ts.config.js', 'openapi-ts.config.cjs', 'openapi-ts.config.mjs']; +// Mapping of all dependencies required by each client. These should be installed in the generated client package +const clientDependencies: Record = { + angular: ['@angular/common', 'rxjs'], + axios: ['axios', 'form-data'], + fetch: [], + node: ['form-data', 'node-fetch'], + xhr: [], +}; + const processOutput = (config: Config, dependencies: Dependencies) => { if (config.format) { if (dependencies.prettier) { @@ -35,11 +44,10 @@ const processOutput = (config: Config, dependencies: Dependencies) => { }; const inferClient = (dependencies: Dependencies): Config['client'] => { - if (dependencies['@angular/cli']) { - return 'angular'; - } - if (dependencies.axios) { - return 'axios'; + for (const [c, deps] of Object.entries(clientDependencies)) { + if (deps.every(d => dependencies[d])) { + return c as Config['client']; + } } return 'fetch'; }; @@ -59,6 +67,13 @@ const logClientMessage = (client: Config['client']) => { } }; +const logMissingDependenciesWarning = (client: Config['client'], dependencies: Dependencies) => { + const missing = clientDependencies[client].filter(d => dependencies[d] === undefined); + if (missing.length > 0) { + console.log('❗️ Missing required dependencies: ' + missing.join(' ')); + } +}; + const getConfigFromFile = async (): Promise => { const configPath = configFiles .map(file => pathToFileURL(path.resolve(process.cwd(), file))) @@ -111,6 +126,9 @@ const getConfig = async (userConfig: UserConfig, dependencies: Dependencies) => } const client = userConfig.client || inferClient(dependencies); + + logMissingDependenciesWarning(client, dependencies); + const output = path.resolve(process.cwd(), userConfig.output); const config: Config = {