150 lines
2.9 KiB
JavaScript
150 lines
2.9 KiB
JavaScript
import svelte from "rollup-plugin-svelte";
|
|
import resolve from "rollup-plugin-node-resolve";
|
|
import commonjs from "rollup-plugin-commonjs";
|
|
import livereload from "rollup-plugin-livereload";
|
|
import { terser } from "rollup-plugin-terser";
|
|
import json from "rollup-plugin-json";
|
|
import alias from "rollup-plugin-alias";
|
|
import path from "path";
|
|
|
|
const aliases = {
|
|
resolve: [".js", ".svelte"],
|
|
entries: [
|
|
{ find: "@BBMD", replacement: path.resolve(__dirname, "dist/index.js") }
|
|
]
|
|
};
|
|
|
|
const production = !process.env.ROLLUP_WATCH;
|
|
|
|
const lodash_fp_exports = [
|
|
"find",
|
|
"isUndefined",
|
|
"split",
|
|
"max",
|
|
"last",
|
|
"union",
|
|
"reduce",
|
|
"isObject",
|
|
"cloneDeep",
|
|
"some",
|
|
"isArray",
|
|
"map",
|
|
"filter",
|
|
"keys",
|
|
"isFunction",
|
|
"isEmpty",
|
|
"countBy",
|
|
"join",
|
|
"includes",
|
|
"flatten",
|
|
"constant",
|
|
"first",
|
|
"intersection",
|
|
"take",
|
|
"has",
|
|
"mapValues",
|
|
"isString",
|
|
"isBoolean",
|
|
"isNull",
|
|
"isNumber",
|
|
"isObjectLike",
|
|
"isDate",
|
|
"clone",
|
|
"values",
|
|
"keyBy",
|
|
"isNaN",
|
|
"isInteger",
|
|
"toNumber"
|
|
];
|
|
|
|
const lodash_exports = [
|
|
"flow",
|
|
"head",
|
|
"find",
|
|
"each",
|
|
"tail",
|
|
"findIndex",
|
|
"startsWith",
|
|
"dropRight",
|
|
"takeRight",
|
|
"trim",
|
|
"split",
|
|
"replace",
|
|
"merge",
|
|
"assign"
|
|
];
|
|
|
|
const coreExternal = [
|
|
"lodash",
|
|
"lodash/fp",
|
|
"date-fns",
|
|
"lunr",
|
|
"safe-buffer",
|
|
"shortid",
|
|
"@nx-js/compiler-util",
|
|
"bcryptjs"
|
|
];
|
|
|
|
export default {
|
|
input: "src/Test/testMain.js",
|
|
output: {
|
|
sourcemap: true,
|
|
format: "iife",
|
|
name: "app",
|
|
file: "public/build/bundle.js",
|
|
globals: {
|
|
crypto: "crypto"
|
|
}
|
|
},
|
|
plugins: [
|
|
alias(aliases),
|
|
svelte({
|
|
// enable run-time checks when not in production
|
|
dev: !production,
|
|
// we'll extract any component CSS out into
|
|
// a separate file — better for performance
|
|
css: css => {
|
|
css.write("public/build/bundle.css");
|
|
},
|
|
|
|
hydratable: true
|
|
}),
|
|
|
|
// If you have external dependencies installed from
|
|
// npm, you'll most likely need these plugins. In
|
|
// some cases you'll need additional configuration —
|
|
// consult the documentation for details:
|
|
// https://github.com/rollup/rollup-plugin-commonjs
|
|
resolve({
|
|
browser: true,
|
|
dedupe: importee => {
|
|
return (
|
|
importee === "svelte" ||
|
|
importee.startsWith("svelte/") ||
|
|
coreExternal.includes(importee)
|
|
);
|
|
},
|
|
preferBuiltins: true
|
|
}),
|
|
commonjs({
|
|
namedExports: {
|
|
"lodash/fp": lodash_fp_exports,
|
|
lodash: lodash_exports,
|
|
shortid: ["generate"]
|
|
}
|
|
}),
|
|
json(),
|
|
|
|
// Watch the `public` directory and refresh the
|
|
// browser on changes when not in production
|
|
!production && livereload("public"),
|
|
|
|
// If we're building for production (npm run build
|
|
// instead of npm run dev), minify
|
|
production && terser()
|
|
],
|
|
watch: {
|
|
clearScreen: false
|
|
}
|
|
};
|