-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
37 lines (29 loc) · 1.26 KB
/
gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
const { src, dest } = require('gulp');
const { relative, extname, join } = require('path');
const { getParsedCommandLineOfConfigFile, sys, ScriptKind, Extension } = require('typescript');
const glob = require('glob');
function asExtension(extension) {
return { extension, scriptKind: ScriptKind.Deferred };
}
async function assets() {
// File extensions we want to copy as assets.
const assetExtensions = ['.png', '.jpg', '.html', '.scss', '.css', '.json', '.jsonc'];
// Let Typescript handle these file extensions and retrieve all other files with the given asset extensions.
const typescriptExtensions = [Extension.Ts, Extension.Tsx, Extension.Js, Extension.Jsx];
const parsed = getParsedCommandLineOfConfigFile(
'tsconfig.json',
{},
sys,
undefined,
undefined,
assetExtensions.map(asExtension),
);
const assetFiles = glob
.sync('src/**/*', { nodir: true })
.filter((fileName) => !typescriptExtensions.includes(extname(fileName)));
console.log(assetFiles);
console.log(parsed.options.rootDir + ' -> ' + parsed.options.outDir);
const base = relative(parsed.options.baseUrl, parsed.options.rootDir);
return src(assetFiles, { base, cwd: parsed.options.baseUrl }).pipe(dest(parsed.options.outDir));
}
module.exports = { assets };