const fs = require('fs'); const gulp = require('gulp'); const less = require('gulp-less'); const sourcemaps = require('gulp-sourcemaps'); const tsc = require('gulp-typescript'); const del = require('del'); const path = require('path'); const replace = require('gulp-replace'); const template = require('gulp-template'); const tap = require('gulp-tap'); const rename = require('gulp-rename'); const tsProject = tsc.createProject('./tsconfig.json'); gulp.task('clean', function () { return del('lib'); }); /** * Compile all typescript files * and copy to the destination */ gulp.task('compile', function () { return tsProject .src() .pipe(sourcemaps.init()) .pipe(tsProject()) .pipe(sourcemaps.write('.', { sourceRoot: './', includeContent: false })) .on('error', (err) => console.log(err)) .pipe(gulp.dest('lib')); }); gulp.task('less', function () { return gulp .src('./src/**/*.less') .pipe(sourcemaps.init()) .pipe(less()) .pipe(sourcemaps.write()) .pipe(gulp.dest(path.join(__dirname, 'lib/src'))); }); const extractFileNameFromPath = (filePath) => { const basename = path.basename(filePath); const filename = basename.split('.'); return filename[0]; }; gulp.task('templates', () => { return ( gulp .src('./lib/src/renderer/components/*.js', { base: './lib' }) // tap into the stream to get the current file and compile // the template according to that .pipe( tap(function (file) { const jsFilename = extractFileNameFromPath(file.path); return gulp .src('./src/renderer/react-window.html') .pipe( template({ sourcefile: file.path, }), ) .pipe( replace( /(]*>)/g, function (_s, _match) { const cssFilePath = `lib/src/renderer/styles/${jsFilename}.css`; const doesFileExist = fs.existsSync(cssFilePath); if (doesFileExist) { const style = fs.readFileSync(cssFilePath, 'utf8'); return ''; } return ''; }, ), ) .pipe(rename(`${jsFilename}.html`)) .pipe(gulp.dest('./lib/src/renderer')); }), ) ); }); /** * Copy all assets to JS codebase */ gulp.task('copy', function () { return gulp .src( [ './src/renderer/assets/*', './src/renderer/*.html', './src/locale/*', './package.json', ], { base: './src', }, ) .pipe(gulp.dest('lib/src')); }); /** * Set expiry time for test builds */ gulp.task('setExpiry', function (done) { // Set expiry of 15 days for test builds we create from CI const expiryDays = process.argv[4] || 15; if (expiryDays < 1) { console.log(`Not setting expiry as the value provided is ${expiryDays}`); done(); return; } console.log(`Setting expiry to ${expiryDays} days`); const milliseconds = 24 * 60 * 60 * 1000; const expiryTime = new Date().getTime() + expiryDays * milliseconds; console.log(`Setting expiry time to ${expiryTime}`); const ttlHandlerFile = path.join(__dirname, 'src/app/ttl-handler.ts'); fs.readFile(ttlHandlerFile, 'utf8', function (err, data) { if (err) { console.error(err); return done(err); } // Do a simple search and replace in the `ttl-handler.ts` file const replacementString = `const ttlExpiryTime = ${expiryTime}`; const result = data.replace(/const ttlExpiryTime = -1/g, replacementString); fs.writeFile(ttlHandlerFile, result, 'utf8', function (err) { if (err) { return done(err); } done(); }); }); }); gulp.task( 'build', gulp.series('clean', 'compile', 'less', 'templates', 'copy'), );