tswatch/ts/tswatch.classes.tswatch.ts

111 lines
3.0 KiB
TypeScript
Raw Normal View History

2018-10-28 02:48:43 +02:00
import * as plugins from './tswatch.plugins';
2019-05-09 00:08:40 +02:00
import * as paths from './tswatch.paths';
import * as interfaces from './interfaces';
2018-10-28 02:48:43 +02:00
2019-05-09 00:08:40 +02:00
import { Watcher } from './tswatch.classes.watcher';
2020-03-13 17:43:57 +00:00
import { Parcel } from './tswatch.classes.parcel';
2018-10-28 19:28:08 +01:00
2018-10-28 02:48:43 +02:00
export class TsWatch {
2019-05-09 00:08:40 +02:00
public watchmode: interfaces.TWatchModes;
public watcherMap = new plugins.lik.Objectmap<Watcher>();
2019-10-14 14:53:55 +02:00
public smartserve: plugins.smartserve.SmartServe;
2018-10-28 02:48:43 +02:00
2019-05-09 00:08:40 +02:00
constructor(watchmodeArg: interfaces.TWatchModes) {
2019-05-13 09:48:35 +02:00
this.watchmode = watchmodeArg;
2018-10-28 02:48:43 +02:00
}
/**
2019-05-09 00:08:40 +02:00
* starts the TsWatch instance
2018-10-28 02:48:43 +02:00
*/
2019-05-13 09:48:35 +02:00
public async start() {
2019-05-09 00:08:40 +02:00
switch (this.watchmode) {
case 'test':
2019-10-12 15:07:44 +02:00
this.watcherMap.add(
new Watcher({
filePathToWatch: paths.cwd,
commandToExecute: 'npm run test2',
timeout: null
})
);
2019-05-09 00:08:40 +02:00
break;
case 'gitzone_npm':
2019-10-12 15:07:44 +02:00
this.watcherMap.add(
new Watcher({
filePathToWatch: paths.cwd,
commandToExecute: 'npm run test',
timeout: null
})
);
break;
case 'gitzone_element':
2019-10-12 18:09:41 +02: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!'
);
2019-10-14 14:53:55 +02:00
this.smartserve = new plugins.smartserve.SmartServe({
2019-10-12 17:43:43 +02:00
port: 3001,
2019-10-12 17:12:50 +02:00
injectReload: true,
2020-03-09 14:52:37 +00:00
serveDir: plugins.path.join(paths.cwd, './dist_watch/')
2019-10-12 17:12:50 +02:00
});
2020-03-13 17:43:57 +00:00
const parcel = new Parcel();
await parcel.start();
2019-05-09 00:08:40 +02:00
break;
case 'gitzone_website':
2019-05-13 09:48:35 +02:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
2019-10-12 15:07:44 +02:00
commandToExecute: 'npm run startTs',
2019-05-13 09:48:35 +02:00
timeout: null
})
);
2019-10-12 15:07:44 +02:00
2019-05-13 09:48:35 +02:00
// client directory
2019-10-12 15:07:44 +02:00
this.watcherMap.add(
new Watcher({
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
commandToExecute: 'npm run build',
timeout: null
})
);
2019-05-13 09:48:35 +02:00
break;
2019-10-14 14:57:43 +02: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',
timeout: null
})
);
break;
2019-05-13 09:48:35 +02:00
case 'echoSomething':
const tsWatchInstanceEchoSomething = new Watcher({
2019-10-12 17:34:05 +02:00
filePathToWatch: plugins.path.join(paths.cwd, './ts'),
2019-05-13 09:48:35 +02:00
commandToExecute: 'npm -v',
2019-05-09 00:08:40 +02:00
timeout: null
});
2019-05-13 09:48:35 +02:00
this.watcherMap.add(tsWatchInstanceEchoSomething);
2019-05-09 00:08:40 +02:00
break;
default:
break;
2018-10-28 02:48:43 +02:00
}
2019-05-09 00:08:40 +02:00
this.watcherMap.forEach(async watcher => {
await watcher.start();
});
2019-10-14 14:53:55 +02:00
if (this.smartserve) {
await this.smartserve.start();
}
2018-10-28 02:48:43 +02:00
}
/**
2019-05-09 00:08:40 +02:00
* stops the execution of any active Watchers
2018-10-28 02:48:43 +02:00
*/
2019-05-13 09:48:35 +02:00
public async stop() {
2019-10-14 14:53:55 +02:00
if (this.smartserve) {
await this.smartserve.stop();
}
2019-05-09 00:08:40 +02:00
this.watcherMap.forEach(async watcher => {
await watcher.stop();
2019-05-13 09:48:35 +02:00
});
2018-10-28 02:48:43 +02:00
}
}