From e2a76ab7ca998f1e64ce43d8756bf059e25116a9 Mon Sep 17 00:00:00 2001 From: kamtschatka Date: Sun, 26 May 2024 16:54:43 +0200 Subject: [PATCH] changed the logging to log created bookmarks as an array switch all log output that is just a status to stderr --- apps/cli/src/commands/bookmarks.ts | 16 ++++++++++++---- apps/cli/src/lib/output.ts | 17 ++--------------- 2 files changed, 14 insertions(+), 19 deletions(-) diff --git a/apps/cli/src/commands/bookmarks.ts b/apps/cli/src/commands/bookmarks.ts index b3ab5f22..40442ec1 100644 --- a/apps/cli/src/commands/bookmarks.ts +++ b/apps/cli/src/commands/bookmarks.ts @@ -58,17 +58,23 @@ bookmarkCmd .action(async (opts) => { const api = getAPIClient(); + const results: object[] = []; + const promises = [ ...opts.link.map((url) => api.bookmarks.createBookmark .mutate({ type: "link", url }) - .then(printBookmark) + .then((bookmark: ZBookmark) => { + results.push(normalizeBookmark(bookmark)); + }) .catch(printError(`Failed to add a link bookmark for url "${url}"`)), ), ...opts.note.map((text) => api.bookmarks.createBookmark .mutate({ type: "text", text }) - .then(printBookmark) + .then((bookmark: ZBookmark) => { + results.push(normalizeBookmark(bookmark)); + }) .catch( printError( `Failed to add a text bookmark with text "${text.substring(0, 50)}"`, @@ -82,7 +88,9 @@ bookmarkCmd promises.push( api.bookmarks.createBookmark .mutate({ type: "text", text }) - .then(printBookmark) + .then((bookmark: ZBookmark) => { + results.push(normalizeBookmark(bookmark)); + }) .catch( printError( `Failed to add a text bookmark with text "${text.substring(0, 50)}"`, @@ -91,8 +99,8 @@ bookmarkCmd ); } - // TODO: if you choose JSON output, the output would be multiple JSONs and not a single one, so it would not be parsable --> change behavior? await Promise.allSettled(promises); + printObject(results); }); bookmarkCmd diff --git a/apps/cli/src/lib/output.ts b/apps/cli/src/lib/output.ts index 50000408..34d86461 100644 --- a/apps/cli/src/lib/output.ts +++ b/apps/cli/src/lib/output.ts @@ -27,21 +27,8 @@ export function printObject( */ export function printStatusMessage(success: boolean, message: unknown): void { const status = success ? "Success" : "Error"; - if (getGlobalOptions().json) { - console.log( - JSON.stringify( - { - status, - message, - }, - null, - 4, - ), - ); - } else { - const colorFunction = success ? chalk.green : chalk.red; - console.log(colorFunction(`${status}: ${message}`)); - } + const colorFunction = success ? chalk.green : chalk.red; + console.error(colorFunction(`${status}: ${message}`)); } /**