feat(bundle): add configurable bundle output modes and bundler options (support base64ts, production builds, includeFiles, maxLineLength) and route non-default outputs to a CustomBundleHandler
This commit is contained in:
@@ -3,6 +3,6 @@
|
||||
*/
|
||||
export const commitinfo = {
|
||||
name: '@git.zone/tswatch',
|
||||
version: '3.1.0',
|
||||
version: '3.2.0',
|
||||
description: 'A development tool for automatically watching and re-compiling TypeScript projects upon detecting file changes, enhancing developer workflows.'
|
||||
}
|
||||
|
||||
@@ -44,6 +44,16 @@ export interface IBundleConfig {
|
||||
watchPatterns?: string[];
|
||||
/** If true, trigger server reload after bundling (default: true) */
|
||||
triggerReload?: boolean;
|
||||
/** Output mode: 'bundle' writes JS, 'base64ts' writes base64-encoded TS (default: 'bundle') */
|
||||
outputMode?: 'bundle' | 'base64ts';
|
||||
/** Bundler to use (default: 'esbuild') */
|
||||
bundler?: 'esbuild' | 'rolldown' | 'rspack';
|
||||
/** Whether to produce a production build (default: false) */
|
||||
production?: boolean;
|
||||
/** Files to include alongside the bundle */
|
||||
includeFiles?: (string | { from: string; to: string })[];
|
||||
/** Max chars per line for base64ts output. 0 or undefined = unlimited */
|
||||
maxLineLength?: number;
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -18,6 +18,7 @@ export class TsWatch {
|
||||
public typedserver: plugins.typedserver.TypedServer | null = null;
|
||||
|
||||
private tsbundle = new plugins.tsbundle.TsBundle();
|
||||
private customBundleHandler = new plugins.tsbundle.CustomBundleHandler();
|
||||
private htmlHandler = new plugins.tsbundle.HtmlHandler();
|
||||
private assetsHandler = new plugins.tsbundle.AssetsHandler();
|
||||
|
||||
@@ -128,10 +129,22 @@ export class TsWatch {
|
||||
} else if (fromPath.endsWith('/') || !fromPath.includes('.')) {
|
||||
// Assets directory copy
|
||||
await this.assetsHandler.processAssets();
|
||||
} else if (bundleConfig.outputMode && bundleConfig.outputMode !== 'bundle') {
|
||||
// Non-default outputMode (e.g. base64ts) — use CustomBundleHandler
|
||||
await this.customBundleHandler.processSingleBundle({
|
||||
from: bundleConfig.from,
|
||||
to: bundleConfig.to,
|
||||
outputMode: bundleConfig.outputMode,
|
||||
bundler: bundleConfig.bundler || 'esbuild',
|
||||
production: bundleConfig.production || false,
|
||||
includeFiles: bundleConfig.includeFiles,
|
||||
maxLineLength: bundleConfig.maxLineLength,
|
||||
});
|
||||
} else {
|
||||
// TypeScript bundling
|
||||
// Standard TypeScript bundling (default)
|
||||
await this.tsbundle.build(paths.cwd, fromPath, toPath, {
|
||||
bundler: 'esbuild',
|
||||
bundler: bundleConfig.bundler || 'esbuild',
|
||||
production: bundleConfig.production || false,
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user