turbo-gulp
Version:
Gulp tasks to boost high-quality projects.
117 lines (115 loc) • 14.5 kB
JavaScript
;
/**
* This module defines the tasks to create webpack bundles.
*
* @module task-generators/build-webpack
*/
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
}
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result["default"] = mod;
return result;
}
Object.defineProperty(exports, "__esModule", { value: true });
/** (Placeholder comment, see christopherthielen/typedoc-plugin-external-module-name#6) */
const fancy_log_1 = __importDefault(require("fancy-log"));
const minimatch_1 = require("minimatch");
const path_1 = require("path");
const plugin_error_1 = __importDefault(require("plugin-error"));
const webpack_1 = __importDefault(require("webpack"));
const webpack_merge_1 = __importDefault(require("webpack-merge"));
const webpack_stream_1 = __importDefault(require("webpack-stream"));
const matcher = __importStar(require("../utils/matcher"));
/**
* Return the canonical name of the build-webpack task according to the target name.
*
* @param targetName Current target name
* @returns {string} The canonical of the build-webpack task for the provided target
*/
function getTaskName(targetName) {
return `${targetName}:build:webpack`;
}
exports.getTaskName = getTaskName;
function generateTask(gulp, options) {
const entryFile = options.entry + ".js";
let curWebpack = webpack_1.default;
let userConfiguration = {};
if (options.webpackOptions !== undefined) {
if (options.webpackOptions.webpack !== undefined) {
curWebpack = options.webpackOptions.webpack;
}
if (options.webpackOptions.configuration !== undefined) {
userConfiguration = options.webpackOptions.configuration;
}
}
const angularWebpackConfig = {
context: path_1.resolve(options.projectRoot),
target: "web",
resolve: {
extensions: [".js", ".json"],
},
module: {
loaders: [
{
test: /\.component\.js$/,
loaders: ["angular2-template-loader"],
include: [path_1.resolve(options.srcDir)],
},
{
test: /\.json$/,
loaders: ["json-loader"],
},
{
test: /\.(html|css)$/,
loaders: ["raw-loader"],
},
],
},
plugins: [
new curWebpack.ContextReplacementPlugin(
// The (\\|\/) piece accounts for path separators in posix and Windows
/angular(\\|\/)core(\\|\/)src(\\|\/)linker/, path_1.resolve(options.srcDir), {}),
],
node: {
global: true,
__dirname: true,
__filename: true,
process: true,
Buffer: true,
},
devtool: "inline-source-map",
output: {
filename: "[name].js",
},
};
const task = function () {
return gulp
.src([path_1.posix.join(options.srcDir, entryFile)], { base: options.srcDir })
.pipe(webpack_stream_1.default(
// TODO: Remove `as any` once webpackMerge's typing support the latest version of Webpack (with `EntryFunc`)
webpack_merge_1.default(angularWebpackConfig, userConfiguration),
// TODO: Remove `as any` once gulpWebpack's typing support the latest version of Webpack (with `EntryFunc`)
curWebpack, (err, stats) => {
// TODO: Check if err is `null` or `undefined` (success) and type properly
if (err) {
throw new plugin_error_1.default("_build:webpack", err);
}
fancy_log_1.default("[_build:webpack]", stats.toString({ colors: true }));
}))
.pipe(gulp.dest(options.buildDir));
};
task.displayName = "_build:webpack";
return task;
}
exports.generateTask = generateTask;
function watch(gulp, options) {
const buildTask = generateTask(gulp, options);
const sources = matcher.asString(matcher.join(options.srcDir, new minimatch_1.Minimatch("**/*")));
return gulp.watch(sources, { cwd: options.srcDir }, buildTask);
}
exports.watch = watch;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["task-generators/build-webpack.ts"],"names":[],"mappings":"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","file":"task-generators/build-webpack.js","sourcesContent":["/**\n * This module defines the tasks to create webpack bundles.\n *\n * @module task-generators/build-webpack\n */\n\n/** (Placeholder comment, see christopherthielen/typedoc-plugin-external-module-name#6) */\n\nimport fancyLog from \"fancy-log\";\nimport { FSWatcher } from \"fs\";\nimport { Gulp } from \"gulp\";\nimport { Minimatch } from \"minimatch\";\nimport { posix as path, resolve as sysResolvePath } from \"path\";\nimport PluginError from \"plugin-error\";\nimport webpack from \"webpack\";\nimport webpackMerge from \"webpack-merge\";\nimport webpackStream from \"webpack-stream\";\nimport { TaskFunction } from \"../utils/gulp-task-function\";\nimport * as matcher from \"../utils/matcher\";\n\nexport interface Options {\n  /**\n   * Root of the main project (with package.json)\n   */\n  projectRoot: string;\n\n  /**\n   * Directory containing the JS sources.\n   */\n  srcDir: string;\n\n  /**\n   * Directory were the result will be piped\n   */\n  buildDir: string;\n\n  /**\n   * Entry module, relative to `jsSrcDir`\n   */\n  entry: string;\n\n  webpackOptions?: {\n    /**\n     * Webpack object to use\n     */\n    webpack?: typeof webpack;\n\n    /**\n     * Customize the default webpack configuration\n     */\n    configuration?: webpack.Configuration;\n  };\n}\n\n/**\n * Return the canonical name of the build-webpack task according to the target name.\n *\n * @param targetName Current target name\n * @returns {string} The canonical of the build-webpack task for the provided target\n */\nexport function getTaskName(targetName: string): string {\n  return `${targetName}:build:webpack`;\n}\n\nexport function generateTask(gulp: Gulp, options: Options): TaskFunction {\n  const entryFile: string = options.entry + \".js\";\n  let curWebpack: typeof webpack = webpack;\n  let userConfiguration: webpack.Configuration = {};\n  if (options.webpackOptions !== undefined) {\n    if (options.webpackOptions.webpack !== undefined) {\n      curWebpack = options.webpackOptions.webpack;\n    }\n    if (options.webpackOptions.configuration !== undefined) {\n      userConfiguration = options.webpackOptions.configuration;\n    }\n  }\n\n  const angularWebpackConfig: webpack.Configuration = {\n    context: sysResolvePath(options.projectRoot),\n    target: \"web\",\n    resolve: {\n      extensions: [\".js\", \".json\"],\n    },\n    module: {\n      loaders: [\n        {\n          test: /\\.component\\.js$/,\n          loaders: [\"angular2-template-loader\"],\n          include: [sysResolvePath(options.srcDir)],\n        },\n        {\n          test: /\\.json$/,\n          loaders: [\"json-loader\"],\n        },\n        {\n          test: /\\.(html|css)$/,\n          loaders: [\"raw-loader\"],\n        },\n      ],\n    },\n    plugins: [\n      new curWebpack.ContextReplacementPlugin(\n        // The (\\\\|\\/) piece accounts for path separators in posix and Windows\n        /angular(\\\\|\\/)core(\\\\|\\/)src(\\\\|\\/)linker/,\n        sysResolvePath(options.srcDir),\n        {},\n      ),\n      // new webpack.DefinePlugin({\n      //   \"process.env\": {\n      //     \"NODE_ENV\": JSON.stringify(\"production\")\n      //   }\n      // }),\n      // new webpack.optimize.DedupePlugin(),\n      // new webpack.optimize.UglifyJsPlugin()\n    ],\n    node: {\n      global: true,\n      __dirname: true,\n      __filename: true,\n      process: true,\n      Buffer: true,\n    },\n    devtool: \"inline-source-map\",\n    output: {\n      filename: \"[name].js\",\n    },\n  };\n\n  const task: TaskFunction = function () {\n    return gulp\n      .src([path.join(options.srcDir, entryFile)], {base: options.srcDir})\n      .pipe(webpackStream(\n        // TODO: Remove `as any` once webpackMerge's typing support the latest version of Webpack (with `EntryFunc`)\n        webpackMerge(angularWebpackConfig as any, userConfiguration as any),\n        // TODO: Remove `as any` once gulpWebpack's typing support the latest version of Webpack (with `EntryFunc`)\n        curWebpack as any,\n        (err: Error, stats: webpack.Stats): void => {\n          // TODO: Check if err is `null` or `undefined` (success) and type properly\n          if (<any> err) {\n            throw new PluginError(\"_build:webpack\", err);\n          }\n          fancyLog(\"[_build:webpack]\", stats.toString({colors: true}));\n        }),\n      )\n      .pipe(gulp.dest(options.buildDir));\n  };\n  task.displayName = \"_build:webpack\";\n  return task;\n}\n\nexport function watch(gulp: Gulp, options: Options): FSWatcher {\n  const buildTask: TaskFunction = generateTask(gulp, options);\n  const sources: string = matcher.asString(matcher.join(options.srcDir, new Minimatch(\"**/*\")));\n  return gulp.watch(sources, {cwd: options.srcDir}, buildTask) as FSWatcher;\n}\n"],"sourceRoot":".."}