@git.zone/tsbundle 2.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/assets/tsconfig.json +11 -0
  2. package/cli.js +4 -0
  3. package/dist_ts/00_commitinfo_data.d.ts +8 -0
  4. package/dist_ts/00_commitinfo_data.js +9 -0
  5. package/dist_ts/index.d.ts +5 -0
  6. package/dist_ts/index.js +12 -0
  7. package/dist_ts/interfaces/index.d.ts +13 -0
  8. package/dist_ts/interfaces/index.js +2 -0
  9. package/dist_ts/mod_esbuild/index.child.d.ts +11 -0
  10. package/dist_ts/mod_esbuild/index.child.js +62 -0
  11. package/dist_ts/mod_esbuild/plugins.d.ts +3 -0
  12. package/dist_ts/mod_esbuild/plugins.js +4 -0
  13. package/dist_ts/mod_html/index.d.ts +10 -0
  14. package/dist_ts/mod_html/index.js +43 -0
  15. package/dist_ts/mod_html/plugins.d.ts +3 -0
  16. package/dist_ts/mod_html/plugins.js +4 -0
  17. package/dist_ts/mod_parcel/index.child.d.ts +11 -0
  18. package/dist_ts/mod_parcel/index.child.js +42 -0
  19. package/dist_ts/mod_parcel/plugins.d.ts +3 -0
  20. package/dist_ts/mod_parcel/plugins.js +4 -0
  21. package/dist_ts/mod_rollup/htmlhandler.d.ts +7 -0
  22. package/dist_ts/mod_rollup/htmlhandler.js +37 -0
  23. package/dist_ts/mod_rollup/index.child.d.ts +18 -0
  24. package/dist_ts/mod_rollup/index.child.js +128 -0
  25. package/dist_ts/mod_rollup/plugins.d.ts +10 -0
  26. package/dist_ts/mod_rollup/plugins.js +12 -0
  27. package/dist_ts/paths.d.ts +6 -0
  28. package/dist_ts/paths.js +8 -0
  29. package/dist_ts/plugins.d.ts +10 -0
  30. package/dist_ts/plugins.js +13 -0
  31. package/dist_ts/tsbundle.class.tsbundle.d.ts +4 -0
  32. package/dist_ts/tsbundle.class.tsbundle.js +36 -0
  33. package/dist_ts/tsbundle.class.tsbundleprocess.d.ts +18 -0
  34. package/dist_ts/tsbundle.class.tsbundleprocess.js +135 -0
  35. package/dist_ts/tsbundle.cli.d.ts +1 -0
  36. package/dist_ts/tsbundle.cli.js +36 -0
  37. package/dist_ts/tsbundle.htmlhandler.d.ts +7 -0
  38. package/dist_ts/tsbundle.htmlhandler.js +37 -0
  39. package/dist_ts/tsbundle.logging.d.ts +2 -0
  40. package/dist_ts/tsbundle.logging.js +14 -0
  41. package/dist_ts/tsbundle.paths.d.ts +5 -0
  42. package/dist_ts/tsbundle.paths.js +7 -0
  43. package/dist_ts/tsbundle.plugins.d.ts +21 -0
  44. package/dist_ts/tsbundle.plugins.js +25 -0
  45. package/license +19 -0
  46. package/npmextra.json +18 -0
  47. package/package.json +54 -0
  48. package/readme.md +78 -0
  49. package/ts/00_commitinfo_data.ts +8 -0
  50. package/ts/index.ts +13 -0
  51. package/ts/interfaces/index.ts +14 -0
  52. package/ts/mod_esbuild/index.child.ts +82 -0
  53. package/ts/mod_esbuild/plugins.ts +7 -0
  54. package/ts/mod_html/index.ts +47 -0
  55. package/ts/mod_html/plugins.ts +7 -0
  56. package/ts/paths.ts +11 -0
  57. package/ts/plugins.ts +23 -0
  58. package/ts/tsbundle.class.tsbundle.ts +49 -0
  59. package/ts/tsbundle.cli.ts +55 -0
  60. package/ts/tsbundle.logging.ts +15 -0
@@ -0,0 +1,18 @@
1
+ import * as plugins from './tsbundle.plugins.js';
2
+ export declare class TsBundleProcess {
3
+ /**
4
+ * the basic default options for rollup
5
+ */
6
+ getBaseOptions(fromArg: string, toArg: string, argvArg: any): plugins.rollup.RollupOptions;
7
+ getOptionsTest(fromArg: string, toArg: string, argvArg: any): plugins.rollup.RollupOptions;
8
+ getOptionsProduction(fromArg: string, toArg: string, argvArg: any): plugins.rollup.RollupOptions;
9
+ constructor();
10
+ /**
11
+ * creates a bundle for the test enviroment
12
+ */
13
+ buildTest(fromArg: string, toArg: string, bundlerArg: 'rollup' | 'parcel', argvArg: any): Promise<void>;
14
+ /**
15
+ * creates a bundle for the production environment
16
+ */
17
+ buildProduction(fromArg: string, toArg: string, argvArg: any): Promise<void>;
18
+ }
@@ -0,0 +1,135 @@
1
+ import * as plugins from './tsbundle.plugins.js';
2
+ import { logger } from './tsbundle.logging.js';
3
+ export class TsBundleProcess {
4
+ /**
5
+ * the basic default options for rollup
6
+ */
7
+ getBaseOptions(fromArg = `ts_web/index.ts`, toArg = 'dist_bundle/bundle.js', argvArg) {
8
+ logger.log('info', `from: ${fromArg}`);
9
+ logger.log('info', `to: ${toArg}`);
10
+ const baseOptions = {
11
+ input: fromArg,
12
+ output: {
13
+ name: 'tsbundle',
14
+ file: toArg,
15
+ format: 'iife',
16
+ sourcemap: true,
17
+ },
18
+ // Indicate here external modules you don't wanna include in your bundle (i.e.: 'lodash')
19
+ external: [],
20
+ watch: {
21
+ include: ['src/**'],
22
+ },
23
+ plugins: [
24
+ // Compile TypeScript files
25
+ plugins.rollupTypescript({
26
+ include: plugins.path.parse(fromArg).dir
27
+ ? plugins.path.parse(fromArg).dir + '/**/*.ts'
28
+ : '**/*.ts',
29
+ declaration: false,
30
+ emitDecoratorMetadata: true,
31
+ experimentalDecorators: true,
32
+ inlineSourceMap: true,
33
+ noEmitOnError: true,
34
+ lib: ['dom'],
35
+ noImplicitAny: false,
36
+ target: 'es2020',
37
+ module: 'es2020',
38
+ moduleResolution: 'node12',
39
+ allowSyntheticDefaultImports: true,
40
+ importsNotUsedAsValues: 'preserve',
41
+ ...(argvArg && argvArg.skiplibcheck
42
+ ? {
43
+ skipLibCheck: true,
44
+ }
45
+ : {}),
46
+ ...(argvArg && argvArg.allowimplicitany
47
+ ? {
48
+ noImplicitAny: false,
49
+ }
50
+ : {}),
51
+ ...(argvArg && argvArg.commonjs
52
+ ? {
53
+ module: 'commonjs',
54
+ moduleResolution: 'node',
55
+ }
56
+ : {}),
57
+ }),
58
+ plugins.rollupJson(),
59
+ // Allow node_modules resolution, so you can use 'external' to control
60
+ // which external modules to include in the bundle
61
+ // https://github.com/rollup/rollup-plugin-node-resolve#usage
62
+ plugins.rollupResolve(),
63
+ plugins.rollupCommonjs({}),
64
+ // Resolve source maps to the original source
65
+ plugins.rollupSourceMaps(),
66
+ ],
67
+ };
68
+ return baseOptions;
69
+ }
70
+ getOptionsTest(fromArg, toArg, argvArg) {
71
+ return this.getBaseOptions(fromArg, toArg, argvArg);
72
+ }
73
+ getOptionsProduction(fromArg, toArg, argvArg) {
74
+ const productionOptions = this.getBaseOptions(fromArg, toArg, argvArg);
75
+ productionOptions.plugins.push(plugins.rollupTerser({
76
+ compress: true,
77
+ mangle: true,
78
+ }));
79
+ return productionOptions;
80
+ }
81
+ constructor() {
82
+ // Nothing here
83
+ }
84
+ /**
85
+ * creates a bundle for the test enviroment
86
+ */
87
+ async buildTest(fromArg, toArg, bundlerArg = 'rollup', argvArg) {
88
+ // create a bundle
89
+ switch (bundlerArg) {
90
+ case 'rollup':
91
+ logger.log('info', `bundling for TEST!`);
92
+ const buildOptions = this.getOptionsTest(fromArg, toArg, argvArg);
93
+ const bundle = await plugins.rollup.rollup(buildOptions);
94
+ bundle.generate(buildOptions.output);
95
+ await bundle.write(buildOptions.output);
96
+ logger.log('ok', `Successfully bundled files!`);
97
+ process.exit(0);
98
+ case 'parcel':
99
+ const parsedPath = plugins.path.parse(toArg);
100
+ const parcelInstance = new plugins.smartparcel.Parcel(fromArg, parsedPath.dir, parsedPath.base);
101
+ await parcelInstance.build();
102
+ }
103
+ }
104
+ /**
105
+ * creates a bundle for the production environment
106
+ */
107
+ async buildProduction(fromArg, toArg, argvArg) {
108
+ // create a bundle
109
+ logger.log('info', `bundling for PRODUCTION!`);
110
+ const buildOptions = this.getOptionsProduction(fromArg, toArg, argvArg);
111
+ const bundle = await plugins.rollup.rollup(buildOptions);
112
+ bundle.generate(buildOptions.output);
113
+ await bundle.write(buildOptions.output);
114
+ logger.log('ok', `Successfully bundled files!`);
115
+ process.exit(0);
116
+ }
117
+ }
118
+ const run = async () => {
119
+ console.log('running spawned compilation process');
120
+ console.log(`cwd: ${process.env.tsbundleCwd}`);
121
+ console.log(`from: ${process.env.tsbundleFrom}`);
122
+ console.log(`to: ${process.env.tsbundleTo}`);
123
+ console.log(`mode: ${process.env.tsbundleMode}`);
124
+ process.chdir(process.env.tsbundleCwd);
125
+ console.log(`switched to ${process.cwd()}`);
126
+ const tsbundleProcessInstance = new TsBundleProcess();
127
+ if (process.env.tsbundleMode === 'test') {
128
+ tsbundleProcessInstance.buildTest(process.env.tsbundleFrom, process.env.tsbundleTo, process.env.tsbundleBundler, JSON.parse(process.env.tsbundleArgv));
129
+ }
130
+ else {
131
+ tsbundleProcessInstance.buildProduction(process.env.tsbundleFrom, process.env.tsbundleTo, JSON.parse(process.env.tsbundleArgv));
132
+ }
133
+ };
134
+ run();
135
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUuY2xhc3MudHNidW5kbGVwcm9jZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvdHNidW5kbGUuY2xhc3MudHNidW5kbGVwcm9jZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sdUJBQXVCLENBQUM7QUFDakQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRS9DLE1BQU0sT0FBTyxlQUFlO0lBQzFCOztPQUVHO0lBQ0ksY0FBYyxDQUNuQixVQUFrQixpQkFBaUIsRUFDbkMsUUFBZ0IsdUJBQXVCLEVBQ3ZDLE9BQVk7UUFFWixNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxTQUFTLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDdkMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsT0FBTyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBRW5DLE1BQU0sV0FBVyxHQUFpQztZQUNoRCxLQUFLLEVBQUUsT0FBTztZQUNkLE1BQU0sRUFBRTtnQkFDTixJQUFJLEVBQUUsVUFBVTtnQkFDaEIsSUFBSSxFQUFFLEtBQUs7Z0JBQ1gsTUFBTSxFQUFFLE1BQU07Z0JBQ2QsU0FBUyxFQUFFLElBQUk7YUFDaEI7WUFDRCx5RkFBeUY7WUFDekYsUUFBUSxFQUFFLEVBQUU7WUFDWixLQUFLLEVBQUU7Z0JBQ0wsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDO2FBQ3BCO1lBQ0QsT0FBTyxFQUFFO2dCQUNQLDJCQUEyQjtnQkFDMUIsT0FBTyxDQUFDLGdCQUF3QixDQUFDO29CQUNoQyxPQUFPLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRzt3QkFDdEMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsR0FBRyxVQUFVO3dCQUM5QyxDQUFDLENBQUMsU0FBUztv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
@@ -0,0 +1 @@
1
+ export declare const runCli: () => Promise<void>;
@@ -0,0 +1,36 @@
1
+ import * as plugins from './plugins.js';
2
+ import { TsBundle } from './tsbundle.class.tsbundle.js';
3
+ import { HtmlHandler } from './mod_html/index.js';
4
+ import { logger } from './tsbundle.logging.js';
5
+ export const runCli = async () => {
6
+ const tsBundleCli = new plugins.smartcli.Smartcli();
7
+ tsBundleCli.standardCommand().subscribe(async (argvArg) => {
8
+ const tsbundle = new TsBundle();
9
+ await tsbundle.build(process.cwd(), argvArg.from, argvArg.to, argvArg);
10
+ return;
11
+ });
12
+ tsBundleCli.addCommand('element').subscribe(async (argvArg) => {
13
+ const tsbundle = new TsBundle();
14
+ await tsbundle.build(process.cwd(), './ts_web/index.ts', './dist_bundle/bundle.js', argvArg);
15
+ });
16
+ tsBundleCli.addCommand('npm').subscribe(async (argvArg) => {
17
+ const tsbundle = new TsBundle();
18
+ const htmlHandler = new HtmlHandler();
19
+ await tsbundle.build(process.cwd(), './ts/index.ts', './dist_bundle/bundle.js', argvArg);
20
+ });
21
+ tsBundleCli.addCommand('website').subscribe(async (argvArg) => {
22
+ const tsbundle = new TsBundle();
23
+ const htmlHandler = new HtmlHandler();
24
+ await tsbundle.build(process.cwd(), './ts_web/index.ts', './dist_serve/bundle.js', argvArg);
25
+ const htmlFiles = await plugins.smartfile.fs.listFiles('./html', /\.html/);
26
+ for (const htmlFile of htmlFiles) {
27
+ await htmlHandler.processHtml({
28
+ from: `./html/${htmlFile}`,
29
+ to: `./dist_serve/${htmlFile}`,
30
+ minify: true,
31
+ });
32
+ }
33
+ });
34
+ tsBundleCli.startParse();
35
+ };
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUuY2xpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvdHNidW5kbGUuY2xpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRS9DLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxLQUFLLElBQUksRUFBRTtJQUMvQixNQUFNLFdBQVcsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDcEQsV0FBVyxDQUFDLGVBQWUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDeEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNoQyxNQUFNLFFBQVEsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUFFLE9BQU8sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN2RSxPQUFPO0lBQ1QsQ0FBQyxDQUFDLENBQUM7SUFFSCxXQUFXLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDNUQsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNoQyxNQUFNLFFBQVEsQ0FBQyxLQUFLLENBQ2xCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFDYixtQkFBbUIsRUFDbkIseUJBQXlCLEVBQ3pCLE9BQU8sQ0FDUixDQUFDO0lBQ0osQ0FBQyxDQUFDLENBQUM7SUFFSCxXQUFXLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDeEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNoQyxNQUFNLFdBQVcsR0FBRyxJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sUUFBUSxDQUFDLEtBQUssQ0FDbEIsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUNiLGVBQWUsRUFDZix5QkFBeUIsRUFDekIsT0FBTyxDQUNSLENBQUM7SUFDSixDQUFDLENBQUMsQ0FBQztJQUVILFdBQVcsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRTtRQUM1RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDdEMsTUFBTSxRQUFRLENBQUMsS0FBSyxDQUNsQixPQUFPLENBQUMsR0FBRyxFQUFFLEVBQ2IsbUJBQW1CLEVBQ25CLHdCQUF3QixFQUN4QixPQUFPLENBQ1IsQ0FBQztRQUNGLE1BQU0sU0FBUyxHQUFHLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMzRSxLQUFLLE1BQU0sUUFBUSxJQUFJLFNBQVMsRUFBRTtZQUNoQyxNQUFNLFdBQVcsQ0FBQyxXQUFXLENBQUM7Z0JBQzVCLElBQUksRUFBRSxVQUFVLFFBQVEsRUFBRTtnQkFDMUIsRUFBRSxFQUFFLGdCQUFnQixRQUFRLEVBQUU7Z0JBQzlCLE1BQU0sRUFBRSxJQUFJO2FBQ2IsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUVILFdBQVcsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUMzQixDQUFDLENBQUMifQ==
@@ -0,0 +1,7 @@
1
+ export declare class HtmlHandler {
2
+ sourceFilePath: string;
3
+ targetFilePath: string;
4
+ checkIfExists(): Promise<boolean>;
5
+ copyHtml(targetPathArg?: string): Promise<void>;
6
+ minifyHtml(targetPathArg?: string): Promise<void>;
7
+ }
@@ -0,0 +1,37 @@
1
+ import * as plugins from './tsbundle.plugins.js';
2
+ import * as paths from './tsbundle.paths.js';
3
+ export class HtmlHandler {
4
+ constructor() {
5
+ this.sourceFilePath = plugins.path.join(paths.htmlDir, 'index.html');
6
+ this.targetFilePath = plugins.path.join(paths.distServeDir, 'index.html');
7
+ }
8
+ async checkIfExists() {
9
+ return plugins.smartfile.fs.fileExists(this.sourceFilePath);
10
+ }
11
+ // copies the html
12
+ async copyHtml(targetPathArg = this.targetFilePath) {
13
+ if (!(await this.checkIfExists())) {
14
+ return;
15
+ }
16
+ await plugins.smartfile.fs.copy(this.sourceFilePath, targetPathArg);
17
+ }
18
+ // copies and minifies the html
19
+ async minifyHtml(targetPathArg = this.targetFilePath) {
20
+ if (!(await this.checkIfExists())) {
21
+ return;
22
+ }
23
+ const fileString = plugins.smartfile.fs.toStringSync(this.sourceFilePath);
24
+ const minifiedHtml = plugins.htmlMinifier.minify(fileString, {
25
+ minifyCSS: true,
26
+ minifyJS: true,
27
+ sortAttributes: true,
28
+ sortClassName: true,
29
+ removeAttributeQuotes: true,
30
+ collapseWhitespace: true,
31
+ collapseInlineTagWhitespace: true,
32
+ removeComments: true,
33
+ });
34
+ plugins.smartfile.memory.toFsSync(minifiedHtml, targetPathArg);
35
+ }
36
+ }
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUuaHRtbGhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c2J1bmRsZS5odG1saGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHVCQUF1QixDQUFDO0FBQ2pELE9BQU8sS0FBSyxLQUFLLE1BQU0scUJBQXFCLENBQUM7QUFFN0MsTUFBTSxPQUFPLFdBQVc7SUFBeEI7UUFDUyxtQkFBYyxHQUFXLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFDeEUsbUJBQWMsR0FBVyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBZ0N0RixDQUFDO0lBOUJRLEtBQUssQ0FBQyxhQUFhO1FBQ3hCLE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsa0JBQWtCO0lBQ1gsS0FBSyxDQUFDLFFBQVEsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGNBQWM7UUFDdkQsSUFBSSxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsRUFBRTtZQUNqQyxPQUFPO1NBQ1I7UUFDRCxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRCwrQkFBK0I7SUFDeEIsS0FBSyxDQUFDLFVBQVUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGNBQWM7UUFDekQsSUFBSSxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsRUFBRTtZQUNqQyxPQUFPO1NBQ1I7UUFDRCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQzFFLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRTtZQUMzRCxTQUFTLEVBQUUsSUFBSTtZQUNmLFFBQVEsRUFBRSxJQUFJO1lBQ2QsY0FBYyxFQUFFLElBQUk7WUFDcEIsYUFBYSxFQUFFLElBQUk7WUFDbkIscUJBQXFCLEVBQUUsSUFBSTtZQUMzQixrQkFBa0IsRUFBRSxJQUFJO1lBQ3hCLDJCQUEyQixFQUFFLElBQUk7WUFDakMsY0FBYyxFQUFFLElBQUk7U0FDckIsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFlBQVksRUFBRSxhQUFhLENBQUMsQ0FBQztJQUNqRSxDQUFDO0NBQ0YifQ==
@@ -0,0 +1,2 @@
1
+ import * as plugins from './plugins.js';
2
+ export declare const logger: plugins.smartlog.Smartlog;
@@ -0,0 +1,14 @@
1
+ import * as plugins from './plugins.js';
2
+ export const logger = new plugins.smartlog.Smartlog({
3
+ logContext: {
4
+ company: 'Some Company',
5
+ companyunit: 'Some CompanyUnit',
6
+ containerName: 'Some Containername',
7
+ environment: 'local',
8
+ runtime: 'node',
9
+ zone: 'gitzone',
10
+ },
11
+ minimumLogLevel: 'silly',
12
+ });
13
+ logger.addLogDestination(new plugins.smartlogDestinationLocal.DestinationLocal());
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUubG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3RzYnVuZGxlLmxvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7SUFDbEQsVUFBVSxFQUFFO1FBQ1YsT0FBTyxFQUFFLGNBQWM7UUFDdkIsV0FBVyxFQUFFLGtCQUFrQjtRQUMvQixhQUFhLEVBQUUsb0JBQW9CO1FBQ25DLFdBQVcsRUFBRSxPQUFPO1FBQ3BCLE9BQU8sRUFBRSxNQUFNO1FBQ2YsSUFBSSxFQUFFLFNBQVM7S0FDaEI7SUFDRCxlQUFlLEVBQUUsT0FBTztDQUN6QixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsaUJBQWlCLENBQUMsSUFBSSxPQUFPLENBQUMsd0JBQXdCLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDIn0=
@@ -0,0 +1,5 @@
1
+ export declare const cwd: string;
2
+ export declare const packageDir: string;
3
+ export declare const htmlDir: string;
4
+ export declare const distServeDir: string;
5
+ export declare const assetsDir: string;
@@ -0,0 +1,7 @@
1
+ import * as plugins from './tsbundle.plugins.js';
2
+ export const cwd = process.cwd();
3
+ export const packageDir = plugins.path.join(plugins.smartpath.get.dirnameFromImportMetaUrl(import.meta.url), '../');
4
+ export const htmlDir = plugins.path.join(cwd, './html');
5
+ export const distServeDir = plugins.path.join(cwd, './dist_serve');
6
+ export const assetsDir = plugins.path.join(packageDir, 'assets');
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUucGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c2J1bmRsZS5wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHVCQUF1QixDQUFDO0FBRWpELE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDakMsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUN6QyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUMvRCxLQUFLLENBQ04sQ0FBQztBQUNGLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLENBQUM7QUFDeEQsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxjQUFjLENBQUMsQ0FBQztBQUNuRSxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDIn0=
@@ -0,0 +1,21 @@
1
+ import * as path from 'path';
2
+ export { path };
3
+ import * as smartcli from '@pushrocks/smartcli';
4
+ import * as smartfile from '@pushrocks/smartfile';
5
+ import * as smartlog from '@pushrocks/smartlog';
6
+ import * as smartlogDestinationLocal from '@pushrocks/smartlog-destination-local';
7
+ import * as smartpath from '@pushrocks/smartpath';
8
+ import * as smartparcel from '@pushrocks/smartparcel';
9
+ import * as smartpromise from '@pushrocks/smartpromise';
10
+ import * as smartspawn from '@pushrocks/smartspawn';
11
+ export { smartcli, smartfile, smartlog, smartlogDestinationLocal, smartpath, smartparcel, smartpromise, smartspawn, };
12
+ import * as rollup from 'rollup';
13
+ import rollupBabel from 'rollup-plugin-babel';
14
+ import rollupCommonjs from '@rollup/plugin-commonjs';
15
+ import rollupJson from '@rollup/plugin-json';
16
+ import rollupResolve from '@rollup/plugin-node-resolve';
17
+ import rollupSourceMaps from 'rollup-plugin-sourcemaps';
18
+ import { terser as rollupTerser } from 'rollup-plugin-terser';
19
+ import rollupTypescript from '@rollup/plugin-typescript';
20
+ import * as htmlMinifier from 'html-minifier';
21
+ export { rollup, rollupBabel, rollupCommonjs, rollupJson, rollupResolve, rollupSourceMaps, rollupTerser, rollupTypescript, htmlMinifier, };
@@ -0,0 +1,25 @@
1
+ // node native
2
+ import * as path from 'path';
3
+ export { path };
4
+ // pushrocks scope
5
+ import * as smartcli from '@pushrocks/smartcli';
6
+ import * as smartfile from '@pushrocks/smartfile';
7
+ import * as smartlog from '@pushrocks/smartlog';
8
+ import * as smartlogDestinationLocal from '@pushrocks/smartlog-destination-local';
9
+ import * as smartpath from '@pushrocks/smartpath';
10
+ import * as smartparcel from '@pushrocks/smartparcel';
11
+ import * as smartpromise from '@pushrocks/smartpromise';
12
+ import * as smartspawn from '@pushrocks/smartspawn';
13
+ export { smartcli, smartfile, smartlog, smartlogDestinationLocal, smartpath, smartparcel, smartpromise, smartspawn, };
14
+ // third party scope
15
+ import * as rollup from 'rollup';
16
+ import rollupBabel from 'rollup-plugin-babel';
17
+ import rollupCommonjs from '@rollup/plugin-commonjs';
18
+ import rollupJson from '@rollup/plugin-json';
19
+ import rollupResolve from '@rollup/plugin-node-resolve';
20
+ import rollupSourceMaps from 'rollup-plugin-sourcemaps';
21
+ import { terser as rollupTerser } from 'rollup-plugin-terser';
22
+ import rollupTypescript from '@rollup/plugin-typescript';
23
+ import * as htmlMinifier from 'html-minifier';
24
+ export { rollup, rollupBabel, rollupCommonjs, rollupJson, rollupResolve, rollupSourceMaps, rollupTerser, rollupTypescript, htmlMinifier, };
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNidW5kbGUucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3RzYnVuZGxlLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQztBQUVoQixrQkFBa0I7QUFDbEIsT0FBTyxLQUFLLFFBQVEsTUFBTSxxQkFBcUIsQ0FBQztBQUNoRCxPQUFPLEtBQUssU0FBUyxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sS0FBSyxRQUFRLE1BQU0scUJBQXFCLENBQUM7QUFDaEQsT0FBTyxLQUFLLHdCQUF3QixNQUFNLHVDQUF1QyxDQUFDO0FBQ2xGLE9BQU8sS0FBSyxTQUFTLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxLQUFLLFdBQVcsTUFBTSx3QkFBd0IsQ0FBQztBQUN0RCxPQUFPLEtBQUssWUFBWSxNQUFNLHlCQUF5QixDQUFDO0FBQ3hELE9BQU8sS0FBSyxVQUFVLE1BQU0sdUJBQXVCLENBQUM7QUFFcEQsT0FBTyxFQUNMLFFBQVEsRUFDUixTQUFTLEVBQ1QsUUFBUSxFQUNSLHdCQUF3QixFQUN4QixTQUFTLEVBQ1QsV0FBVyxFQUNYLFlBQVksRUFDWixVQUFVLEdBQ1gsQ0FBQztBQUVGLG9CQUFvQjtBQUNwQixPQUFPLEtBQUssTUFBTSxNQUFNLFFBQVEsQ0FBQztBQUNqQyxPQUFPLFdBQVcsTUFBTSxxQkFBcUIsQ0FBQztBQUM5QyxPQUFPLGNBQWMsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLFVBQVUsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QyxPQUFPLGFBQWEsTUFBTSw2QkFBNkIsQ0FBQztBQUN4RCxPQUFPLGdCQUFnQixNQUFNLDBCQUEwQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxNQUFNLElBQUksWUFBWSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUQsT0FBTyxnQkFBZ0IsTUFBTSwyQkFBMkIsQ0FBQztBQUV6RCxPQUFPLEtBQUssWUFBWSxNQUFNLGVBQWUsQ0FBQztBQUU5QyxPQUFPLEVBQ0wsTUFBTSxFQUNOLFdBQVcsRUFDWCxjQUFjLEVBQ2QsVUFBVSxFQUNWLGFBQWEsRUFDYixnQkFBZ0IsRUFDaEIsWUFBWSxFQUNaLGdCQUFnQixFQUNoQixZQUFZLEdBQ2IsQ0FBQyJ9
package/license ADDED
@@ -0,0 +1,19 @@
1
+ Copyright (c) 2019 Lossless GmbH (hello@lossless.com)
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining a copy
4
+ of this software and associated documentation files (the "Software"), to deal
5
+ in the Software without restriction, including without limitation the rights
6
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7
+ copies of the Software, and to permit persons to whom the Software is
8
+ furnished to do so, subject to the following conditions:
9
+
10
+ The above copyright notice and this permission notice shall be included in all
11
+ copies or substantial portions of the Software.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
19
+ SOFTWARE.
package/npmextra.json ADDED
@@ -0,0 +1,18 @@
1
+ {
2
+ "gitzone": {
3
+ "projectType": "npm",
4
+ "module": {
5
+ "githost": "gitlab.com",
6
+ "gitscope": "gitzone",
7
+ "gitrepo": "tsbundle",
8
+ "description": "a bundler using rollup for painless bundling of web projects",
9
+ "npmPackagename": "@git.zone/tsbundle",
10
+ "license": "MIT",
11
+ "projectDomain": "git.zone"
12
+ }
13
+ },
14
+ "npmci": {
15
+ "npmGlobalTools": [],
16
+ "npmAccessLevel": "public"
17
+ }
18
+ }
package/package.json ADDED
@@ -0,0 +1,54 @@
1
+ {
2
+ "name": "@git.zone/tsbundle",
3
+ "version": "2.0.9",
4
+ "private": false,
5
+ "description": "a bundler using rollup for painless bundling of web projects",
6
+ "main": "dist_ts/index.js",
7
+ "typings": "dist_ts/index.d.ts",
8
+ "type": "module",
9
+ "author": "Lossless GmbH",
10
+ "license": "MIT",
11
+ "scripts": {
12
+ "test": "npm run build && (tstest test/) && (cd test && node ../cli.js --production)",
13
+ "build": "(tsbuild --web --allowimplicitany)"
14
+ },
15
+ "bin": {
16
+ "tsbundle": "cli.js"
17
+ },
18
+ "devDependencies": {
19
+ "@git.zone/tsbuild": "^2.1.69",
20
+ "@git.zone/tsrun": "^1.2.46",
21
+ "@git.zone/tstest": "^1.0.74",
22
+ "@push.rocks/tapbundle": "^5.0.15",
23
+ "@types/node": "^20.5.6"
24
+ },
25
+ "dependencies": {
26
+ "@push.rocks/early": "^4.0.4",
27
+ "@push.rocks/smartcli": "^4.0.8",
28
+ "@push.rocks/smartfile": "^10.0.30",
29
+ "@push.rocks/smartlog": "^3.0.3",
30
+ "@push.rocks/smartlog-destination-local": "^9.0.0",
31
+ "@push.rocks/smartpath": "^5.0.11",
32
+ "@push.rocks/smartpromise": "^4.0.2",
33
+ "@push.rocks/smartspawn": "^3.0.2",
34
+ "@types/html-minifier": "^4.0.2",
35
+ "esbuild": "^0.19.2",
36
+ "html-minifier": "^4.0.0",
37
+ "typescript": "5.1.6"
38
+ },
39
+ "files": [
40
+ "ts/**/*",
41
+ "ts_web/**/*",
42
+ "dist/**/*",
43
+ "dist_*/**/*",
44
+ "dist_ts/**/*",
45
+ "dist_ts_web/**/*",
46
+ "assets/**/*",
47
+ "cli.js",
48
+ "npmextra.json",
49
+ "readme.md"
50
+ ],
51
+ "browserslist": [
52
+ "last 1 chrome versions"
53
+ ]
54
+ }
package/readme.md ADDED
@@ -0,0 +1,78 @@
1
+ # @git.zone/tsbundle
2
+ a bundler using rollup for painless bundling of web projects
3
+
4
+ ## Availabililty and Links
5
+ * [npmjs.org (npm package)](https://www.npmjs.com/package/@git.zone/tsbundle)
6
+ * [gitlab.com (source)](https://gitlab.com/gitzone/tsbundle)
7
+ * [github.com (source mirror)](https://github.com/gitzone/tsbundle)
8
+ * [docs (typedoc)](https://gitzone.gitlab.io/tsbundle/)
9
+
10
+ ## Status for master
11
+
12
+ Status Category | Status Badge
13
+ -- | --
14
+ GitLab Pipelines | [![pipeline status](https://gitlab.com/gitzone/tsbundle/badges/master/pipeline.svg)](https://lossless.cloud)
15
+ GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/gitzone/tsbundle/badges/master/coverage.svg)](https://lossless.cloud)
16
+ npm | [![npm downloads per month](https://badgen.net/npm/dy/@git.zone/tsbundle)](https://lossless.cloud)
17
+ Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/gitzone/tsbundle)](https://lossless.cloud)
18
+ TypeScript Support | [![TypeScript](https://badgen.net/badge/TypeScript/>=%203.x/blue?icon=typescript)](https://lossless.cloud)
19
+ node Support | [![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
20
+ Code Style | [![Code Style](https://badgen.net/badge/style/prettier/purple)](https://lossless.cloud)
21
+ PackagePhobia (total standalone install weight) | [![PackagePhobia](https://badgen.net/packagephobia/install/@git.zone/tsbundle)](https://lossless.cloud)
22
+ PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@git.zone/tsbundle)](https://lossless.cloud)
23
+ BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@git.zone/tsbundle)](https://lossless.cloud)
24
+ Platform support | [![Supports Windows 10](https://badgen.net/badge/supports%20Windows%2010/yes/green?icon=windows)](https://lossless.cloud) [![Supports Mac OS X](https://badgen.net/badge/supports%20Mac%20OS%20X/yes/green?icon=apple)](https://lossless.cloud)
25
+
26
+ ## Usage
27
+
28
+ Use TypeScript for best in class intellisense.
29
+
30
+ tsbundle will bundle modern JavaScript websites in an Google Bot conformant way so things like AdSense do work.
31
+
32
+ tsbundle supports two modes of usage: CLI and API usage.
33
+
34
+ ### CLI
35
+
36
+ ```shell
37
+ # Note: This is code that belongs into your terminal ;)
38
+ # Install the tool for cli usage
39
+
40
+ # Globally
41
+ npm install -g @git.zone/tsbundle
42
+
43
+ # Locally for use in your pacakge.json
44
+ npm install --save-dev @git.zone/tsbundle
45
+
46
+ # then use it
47
+ tsbundle --from="./ts/index.ts" --to="dist/bundle.js"
48
+
49
+ ## note you can call tsbundle without arguments. Default values are --from="./ts_web/index.ts" --to="dist_bundle/bundle.js"
50
+ ## You can use --production to enable minification using terser
51
+ ```
52
+
53
+ ## API
54
+
55
+ You are using TypeScript, aren't you? Most of the stuff is apparent from the IDE intellisense.
56
+
57
+ ```typescript
58
+ import { TsBundle } from '@gitozne/tsbundle';
59
+
60
+ const myTsBundleInstance = new TsBundle();
61
+
62
+ const run = async () => {
63
+ await myTsBundleInstance.buildTest('./from/my.ts', './to/mybundle.js');
64
+ // OR
65
+ await myTsBundleInstance.buildProduction('./from/my.ts', './to/mybundle.js');
66
+ };
67
+ ```
68
+
69
+ ## Contribution
70
+
71
+ We are always happy for code contributions. If you are not the code contributing type that is ok. Still, maintaining Open Source repositories takes considerable time and thought. If you like the quality of what we do and our modules are useful to you we would appreciate a little monthly contribution: You can [contribute one time](https://lossless.link/contribute-onetime) or [contribute monthly](https://lossless.link/contribute). :)
72
+
73
+ For further information read the linked docs at the top of this readme.
74
+
75
+ > MIT licensed | **&copy;** [Lossless GmbH](https://lossless.gmbh)
76
+ | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
77
+
78
+ [![repo-footer](https://lossless.gitlab.io/publicrelations/repofooter.svg)](https://maintainedby.lossless.com)
@@ -0,0 +1,8 @@
1
+ /**
2
+ * autocreated commitinfo by @pushrocks/commitinfo
3
+ */
4
+ export const commitinfo = {
5
+ name: '@git.zone/tsbundle',
6
+ version: '2.0.9',
7
+ description: 'a bundler using rollup for painless bundling of web projects'
8
+ }
package/ts/index.ts ADDED
@@ -0,0 +1,13 @@
1
+ import * as early from '@push.rocks/early';
2
+ early.start('tsbundle');
3
+ // lets import all plugins beforehand
4
+ import './plugins.js';
5
+
6
+ import { logger } from './tsbundle.logging.js';
7
+ import { runCli } from './tsbundle.cli.js';
8
+ early.stop();
9
+
10
+ // lets make this usable programmatically
11
+ export * from './tsbundle.class.tsbundle.js';
12
+ export * from './mod_html/index.js';
13
+ export { runCli };
@@ -0,0 +1,14 @@
1
+ export interface ICliOptions {
2
+ commonjs?: boolean;
3
+ skiplibcheck?: boolean;
4
+ production?: boolean;
5
+ bundler: 'parcel' | 'esbuild' | 'rollup'
6
+ }
7
+
8
+ export interface IEnvTransportOptions {
9
+ cwd: string;
10
+ from: string;
11
+ to: string;
12
+ mode: 'test' | 'production',
13
+ argv: ICliOptions
14
+ }
@@ -0,0 +1,82 @@
1
+ import * as plugins from './plugins.js';
2
+ import * as paths from '../paths.js';
3
+ import * as interfaces from '../interfaces/index.js';
4
+ import { logger } from '../tsbundle.logging.js';
5
+
6
+ export class TsBundleProcess {
7
+
8
+ constructor() {
9
+ // Nothing here
10
+ }
11
+
12
+ /**
13
+ * creates a bundle for the test enviroment
14
+ */
15
+ public async buildTest(
16
+ fromArg: string,
17
+ toArg: string,
18
+ argvArg: any
19
+ ) {
20
+ // create a bundle
21
+ const esbuild = await plugins.esbuild.build({
22
+ entryPoints: [fromArg],
23
+ bundle: true,
24
+ sourcemap: true,
25
+ format: 'esm',
26
+ target: 'es2020',
27
+ outfile: toArg,
28
+ tsconfig: paths.tsconfigPath
29
+ });
30
+ }
31
+
32
+ /**
33
+ * creates a bundle for the production environment
34
+ */
35
+ public async buildProduction(
36
+ fromArg: string,
37
+ toArg: string,
38
+ argvArg: any
39
+ ) {
40
+ // create a bundle
41
+ console.log('esbuild specific:');
42
+ console.log(`from: ${fromArg}`);
43
+ console.log((`to: ${toArg}`));
44
+ const esbuild = await plugins.esbuild.build({
45
+ entryPoints: [fromArg],
46
+ bundle: true,
47
+ sourcemap: true,
48
+ format: 'esm',
49
+ target: 'es2020',
50
+ minify: true,
51
+ outfile: toArg,
52
+ tsconfig: paths.tsconfigPath
53
+ });
54
+ }
55
+ }
56
+
57
+ const run = async () => {
58
+ console.log('running spawned compilation process');
59
+ const transportOptions: interfaces.IEnvTransportOptions = JSON.parse(process.env.transportOptions);
60
+ console.log('=======> ESBUILD');
61
+ console.log(transportOptions);
62
+ process.chdir(transportOptions.cwd);
63
+ console.log(`switched to ${process.cwd()}`);
64
+ const tsbundleProcessInstance = new TsBundleProcess();
65
+ if (transportOptions.mode === 'test') {
66
+ console.log('building for test:')
67
+ tsbundleProcessInstance.buildTest(
68
+ plugins.smartpath.transform.makeAbsolute(transportOptions.from, process.cwd()),
69
+ plugins.smartpath.transform.makeAbsolute(transportOptions.to, process.cwd()),
70
+ transportOptions.argv
71
+ );
72
+ } else {
73
+ console.log('building for production:')
74
+ tsbundleProcessInstance.buildProduction(
75
+ plugins.smartpath.transform.makeAbsolute(transportOptions.from, process.cwd()),
76
+ plugins.smartpath.transform.makeAbsolute(transportOptions.to, process.cwd()),
77
+ transportOptions.argv
78
+ );
79
+ }
80
+ };
81
+
82
+ run();
@@ -0,0 +1,7 @@
1
+ export * from '../plugins.js';
2
+
3
+ import esbuild from 'esbuild';
4
+
5
+ export {
6
+ esbuild
7
+ }