From c708f19f4c54fa9d210b40cb32bd765869dcd805 Mon Sep 17 00:00:00 2001 From: Nair-VillaGran Date: Fri, 20 Dec 2024 18:05:25 -0500 Subject: [PATCH] refactor(commons): add FeathersGeneratorError and flexible version resolution --- packages/generators/src/commons.ts | 49 ++++++++++++++++++++++++------ 1 file changed, 40 insertions(+), 9 deletions(-) diff --git a/packages/generators/src/commons.ts b/packages/generators/src/commons.ts index ce5cadfafe..280a211456 100644 --- a/packages/generators/src/commons.ts +++ b/packages/generators/src/commons.ts @@ -107,9 +107,11 @@ export interface FeathersBaseContext extends PinionContext { * @param versions The dependency version list * @returns A list of dependencies with their versions */ -export const addVersions = (dependencies: string[], versions: DependencyVersions) => - dependencies.map((dep) => `${dep}@${versions[dep] ? versions[dep] : 'latest'}`) - +export const addVersions = ( + dependencies: string[], + versions: DependencyVersions, + defaultVersion = 'latest' +): string[] => dependencies.map((dep) => `${dep}@${versions[dep] || defaultVersion}`) /** * Loads the application package.json and populates information like the library and test directory * and Feathers app specific information. @@ -138,6 +140,30 @@ export const initializeBaseContext = feathers: ctx.pkg?.feathers })) +/** + * A special error that can be thrown by generators. It contains additional + * information about the error that can be used to display a more helpful + * error message to the user. + */ +export class FeathersGeneratorError extends Error { + /** + * Additional information about the error. This can include things like + * the reason for the error and suggested actions to take. + */ + context?: Record + + /** + * Creates a new FeathersGeneratorError + * @param message The error message + * @param context Additional information about the error + */ + constructor(message: string, context?: Record) { + super(message) + this.name = 'FeathersGeneratorError' + this.context = context + } +} + /** * Checks if the current context contains a valid generated application. This is necesary for most * generators (besides the app generator). @@ -149,11 +175,11 @@ export const checkPreconditions = () => async (ctx: T) => { if (!ctx.feathers) { - throw new Error(`Can not run generator since the current folder does not appear to be a Feathers application. -Either your package.json is missing or it does not have \`feathers\` property. -`) + throw new FeathersGeneratorError('Invalid Feathers application context', { + reason: 'Missing Feathers configuration', + suggestedAction: 'Verify package.json contains Feathers metadata' + }) } - return ctx } @@ -203,8 +229,13 @@ export const PRETTIERRC: PrettierOptions = { printWidth: 110, semi: false, trailingComma: 'none', - singleQuote: true -} + singleQuote: true, + arrowParens: 'avoid', + bracketSpacing: true, + endOfLine: 'auto', + jsxSingleQuote: false, + quoteProps: 'as-needed' +}; /* * Format a source file using Prettier. Will use the local configuration, the settings set in