'use strict'; const gulp = require('gulp'); const build = require('@microsoft/sp-build-web'); build.addSuppression(`Warning - [sass] The local CSS class 'ms-Grid' is not camelCase and will not be type-safe.`); // This section is inspired by Stefan Bauer's article at https://n8d.at/how-to-version-new-sharepoint-framework-projects/ // Stefan rocks! let syncVersionsSubtask = build.subTask('version-sync', function (gulp, buildOptions, done) { this.log('Synching versions'); // import gulp utilits to write error messages const gutil = require('gulp-util'); // import file system utilities form nodeJS const fs = require('fs'); // read package.json var pkgConfig = require('./package.json'); // read configuration of web part solution file var pkgSolution = require('./config/package-solution.json'); // log old version this.log('package-solution.json version:\t' + pkgSolution.solution.version); // Generate new MS compliant version number var newVersionNumber = pkgConfig.version.split('-')[0] + '.0'; if (pkgSolution.solution.version !== newVersionNumber) { // assign newly generated version number to web part version pkgSolution.solution.version = newVersionNumber; // log new version this.log('New package-solution.json version:\t' + pkgSolution.solution.version); fs.writeFile('./config/package-solution.json', JSON.stringify(pkgSolution, null, 4), function (err, result) { if (err) this.log('error', err); }); } else { this.log('package-solution.json version is up-to-date'); } done(); }); let syncVersionTask = build.task('version-sync', syncVersionsSubtask); build.rig.addPreBuildTask(syncVersionTask); build.initialize(gulp);