electron-webpack
Version:
> Because setting up `webpack` in the `electron` environment shouldn't be difficult.
55 lines (45 loc) • 2.28 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.configureVue = configureVue;
exports.configureVueRenderer = configureVueRenderer;
var path = _interopRequireWildcard(require("path"));
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function configureVue(configurator) {
if (!configurator.hasDependency("vue")) {
return;
}
configurator.extensions.push(".vue");
Object.assign(configurator.config.resolve.alias, {
vue$: "vue/dist/vue.esm.js",
"vue-router$": "vue-router/dist/vue-router.esm.js"
});
if (!configurator.isProduction && configurator.type === "main") {
configurator.entryFiles.push(path.join(__dirname, "vue-main-dev-entry.js"));
}
}
function configureVueRenderer(configurator) {
configurator.entryFiles.push(path.join(__dirname, "../../../vue-renderer-entry.js"));
configurator.debug("Vue detected");
configurator.rules.push({
test: /\.html$/,
use: "vue-html-loader"
}, {
test: /\.vue$/,
use: {
loader: "vue-loader",
options: {
loaders: {
sass: "vue-style-loader!css-loader!sass-loader?indentedSyntax=1",
scss: "vue-style-loader!css-loader!sass-loader"
}
}
}
});
const VueLoaderPlugin = require("vue-loader/lib/plugin");
configurator.plugins.push(new VueLoaderPlugin());
}
// __ts-babel@6.0.4
//# sourceMappingURL=vue.js.map