From 96d84f1719c93f5c9fe552848df902172695856e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Ch=C5=82odnicki?= Date: Mon, 20 Mar 2023 05:09:12 -0700 Subject: [PATCH] fix(typescript-build): set logger instance correctly (#580) --- packages/typescript-build/src/index.ts | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/packages/typescript-build/src/index.ts b/packages/typescript-build/src/index.ts index b8a5c4ed..716fd24b 100644 --- a/packages/typescript-build/src/index.ts +++ b/packages/typescript-build/src/index.ts @@ -1,10 +1,11 @@ import path from 'path' import { defu } from 'defu' import consola from 'consola' -import { Module } from '@nuxt/types' -import { Options as TsLoaderOptions } from 'ts-loader' -import { ForkTsCheckerWebpackPluginOptions as TsCheckerOptions } from 'fork-ts-checker-webpack-plugin/lib/ForkTsCheckerWebpackPluginOptions' -import { RuleSetUseItem } from 'webpack' +import type { Module } from '@nuxt/types' +import type { Options as TsLoaderOptions } from 'ts-loader' +import type { ForkTsCheckerWebpackPluginOptions as TsCheckerOptions } from 'fork-ts-checker-webpack-plugin/lib/ForkTsCheckerWebpackPluginOptions' +import type TsCheckerLogger from 'fork-ts-checker-webpack-plugin/lib/logger/Logger' +import type { RuleSetUseItem } from 'webpack' export interface Options { ignoreNotFoundWarnings?: boolean @@ -72,6 +73,13 @@ const tsModule: Module = function (moduleOptions) { if (options.typeCheck && isClient && !isModern) { // eslint-disable-next-line @typescript-eslint/no-var-requires const ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin') + const logger = consola.withTag('nuxt:typescript') + /* istanbul ignore next */ + const loggerInterface: TsCheckerLogger = { + log (message) { logger.log(message) }, + info (message) { logger.info(message) }, + error (message) { logger.error(message) } + } config.plugins!.push(new ForkTsCheckerWebpackPlugin(defu(options.typeCheck, { typescript: { configFile: path.resolve(this.options.rootDir!, 'tsconfig.json'), @@ -79,7 +87,9 @@ const tsModule: Module = function (moduleOptions) { vue: true } }, - logger: consola.withScope('nuxt:typescript') + logger: { + issues: loggerInterface + } } as TsCheckerOptions))) } })