tswatch/ts/tswatch.classes.tswatch.ts

162 lines
4.9 KiB
TypeScript
Raw Permalink Normal View History

2022-03-14 20:17:36 +00:00
import * as plugins from './tswatch.plugins.js';
import * as paths from './tswatch.paths.js';
import * as interfaces from './interfaces/index.js';
2018-10-28 00:48:43 +00:00
2022-03-14 20:17:36 +00:00
import { Watcher } from './tswatch.classes.watcher.js';
2018-10-28 18:28:08 +00:00
2018-10-28 00:48:43 +00:00
export class TsWatch {
2019-05-08 22:08:40 +00:00
public watchmode: interfaces.TWatchModes;
2020-05-22 07:25:34 +00:00
public watcherMap = new plugins.lik.ObjectMap<Watcher>();
2023-03-31 11:10:29 +00:00
public typedserver: plugins.typedserver.TypedServer;
2018-10-28 00:48:43 +00:00
2019-05-08 22:08:40 +00:00
constructor(watchmodeArg: interfaces.TWatchModes) {
2019-05-13 07:48:35 +00:00
this.watchmode = watchmodeArg;
2018-10-28 00:48:43 +00:00
}
/**
2019-05-08 22:08:40 +00:00
* starts the TsWatch instance
2018-10-28 00:48:43 +00:00
*/
2019-05-13 07:48:35 +00:00
public async start() {
2022-03-18 19:16:58 +00:00
const tsbundle = new plugins.tsbundle.TsBundle();
const htmlHandler = new plugins.tsbundle.HtmlHandler();
2019-05-08 22:08:40 +00:00
switch (this.watchmode) {
case 'test':
2019-10-12 13:07:44 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: paths.cwd,
commandToExecute: 'npm run test2',
2020-07-04 10:35:16 +00:00
timeout: null,
2019-10-12 13:07:44 +00:00
})
);
2019-05-08 22:08:40 +00:00
break;
case 'gitzone_npm':
2019-10-12 13:07:44 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: paths.cwd,
commandToExecute: 'npm run test',
2020-07-04 10:35:16 +00:00
timeout: null,
2019-10-12 13:07:44 +00:00
})
);
break;
case 'gitzone_element':
2019-10-12 16:09:41 +00:00
// lets create a standard server
2020-03-13 17:48:19 +00:00
console.log(
'bundling TypeScript files to "dist_watch" Note: This is for development only!'
);
2023-03-31 11:10:29 +00:00
this.typedserver = new plugins.typedserver.TypedServer({
cors: true,
2022-03-18 06:13:20 +00:00
injectReload: true,
2022-03-18 12:18:15 +00:00
serveDir: plugins.path.join(paths.cwd, './dist_watch/'),
2022-03-18 06:13:20 +00:00
port: 3002,
2024-01-09 10:27:52 +00:00
enableCompression: true,
preferredCompressionMethod: 'gzip',
2022-03-18 06:13:20 +00:00
});
2022-08-02 13:38:04 +00:00
2022-03-18 19:32:26 +00:00
const bundleAndReloadElement = async () => {
2022-03-18 15:42:53 +00:00
await tsbundle.build(paths.cwd, './html/index.ts', './dist_watch/bundle.js', {
2022-08-02 13:38:04 +00:00
bundler: 'esbuild',
2022-03-18 12:18:15 +00:00
});
2023-03-31 11:10:29 +00:00
await this.typedserver.reload();
2022-08-02 13:38:04 +00:00
};
2022-03-18 06:13:20 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
2022-03-18 12:18:15 +00:00
functionToCall: async () => {
2022-03-18 19:32:26 +00:00
await bundleAndReloadElement();
2022-03-18 12:18:15 +00:00
},
2022-03-18 06:13:20 +00:00
timeout: null,
})
);
2022-03-18 15:36:13 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
functionToCall: async () => {
2022-08-02 13:38:04 +00:00
await htmlHandler.processHtml({
from: plugins.path.join(paths.cwd, './html/index.html'),
to: plugins.path.join(paths.cwd, './dist_watch/index.html'),
minify: false,
});
2022-03-18 19:32:26 +00:00
await bundleAndReloadElement();
2022-03-18 15:36:13 +00:00
},
timeout: null,
})
);
2019-05-08 22:08:40 +00:00
break;
case 'gitzone_website':
2019-05-13 07:48:35 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
2019-10-12 13:07:44 +00:00
commandToExecute: 'npm run startTs',
2020-07-04 10:35:16 +00:00
timeout: null,
2019-05-13 07:48:35 +00:00
})
);
2022-03-18 19:32:26 +00:00
const bundleAndReloadWebsite = async () => {
2022-03-18 15:36:13 +00:00
await tsbundle.build(paths.cwd, './ts_web/index.ts', './dist_serve/bundle.js', {
2022-08-02 13:38:04 +00:00
bundler: 'esbuild',
2022-03-18 15:36:13 +00:00
});
2022-08-02 13:38:04 +00:00
};
2022-03-18 12:18:15 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
2022-03-18 15:36:13 +00:00
functionToCall: async () => {
2022-03-18 19:32:26 +00:00
await bundleAndReloadWebsite();
2022-03-18 15:36:13 +00:00
},
timeout: null,
})
);
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
functionToCall: async () => {
2022-08-02 13:38:04 +00:00
await htmlHandler.processHtml({
from: plugins.path.join(paths.cwd, './html/index.html'),
to: plugins.path.join(paths.cwd, './dist_serve/index.html'),
minify: false,
});
2022-03-18 19:32:26 +00:00
await bundleAndReloadWebsite();
2022-03-18 15:36:13 +00:00
},
2022-03-18 12:18:15 +00:00
timeout: null,
})
);
2020-07-04 10:49:00 +00:00
break;
2019-10-14 12:57:43 +00:00
case 'gitzone_service':
2020-03-13 17:48:19 +00:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
commandToExecute: 'npm run startTs',
2020-07-04 10:35:16 +00:00
timeout: null,
2020-03-13 17:48:19 +00:00
})
);
break;
2019-05-13 07:48:35 +00:00
case 'echoSomething':
const tsWatchInstanceEchoSomething = new Watcher({
2019-10-12 15:34:05 +00:00
filePathToWatch: plugins.path.join(paths.cwd, './ts'),
2019-05-13 07:48:35 +00:00
commandToExecute: 'npm -v',
2020-07-04 10:35:16 +00:00
timeout: null,
2019-05-08 22:08:40 +00:00
});
2019-05-13 07:48:35 +00:00
this.watcherMap.add(tsWatchInstanceEchoSomething);
2019-05-08 22:08:40 +00:00
break;
default:
break;
2018-10-28 00:48:43 +00:00
}
2020-07-04 10:35:16 +00:00
this.watcherMap.forEach(async (watcher) => {
2019-05-08 22:08:40 +00:00
await watcher.start();
});
2023-03-31 11:10:29 +00:00
if (this.typedserver) {
await this.typedserver.start();
2019-10-14 12:53:55 +00:00
}
2018-10-28 00:48:43 +00:00
}
/**
2019-05-08 22:08:40 +00:00
* stops the execution of any active Watchers
2018-10-28 00:48:43 +00:00
*/
2019-05-13 07:48:35 +00:00
public async stop() {
2023-03-31 11:10:29 +00:00
if (this.typedserver) {
await this.typedserver.stop();
2019-10-14 12:53:55 +00:00
}
2020-07-04 10:35:16 +00:00
this.watcherMap.forEach(async (watcher) => {
2019-05-08 22:08:40 +00:00
await watcher.stop();
2019-05-13 07:48:35 +00:00
});
2018-10-28 00:48:43 +00:00
}
}