123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- import resolve from "@rollup/plugin-node-resolve";
- import replace from "@rollup/plugin-replace";
- import commonjs from "@rollup/plugin-commonjs";
- import json from "@rollup/plugin-json";
- import typescript from "@rollup/plugin-typescript";
- import svelte from "rollup-plugin-svelte";
- import babel from "@rollup/plugin-babel";
- import { terser } from "rollup-plugin-terser";
- import config from "sapper/config/rollup";
- import pkg from "./package.json";
- const preprocess = [
- // eslint-disable-next-line global-require
- require("./svelte.config").preprocess,
- // You could have more preprocessors, like MDsveX
- ];
- const mode = process.env.NODE_ENV;
- const dev = mode === "development";
- const sourcemap = dev ? "inline" : false;
- const legacy = !!process.env.SAPPER_LEGACY_BUILD;
- const warningIsIgnored = (warning) => warning.message.includes(
- "Use of eval is strongly discouraged, as it poses security risks and may cause issues with minification",
- ) || warning.message.includes("Circular dependency: node_modules");
- // Workaround for https://github.com/sveltejs/sapper/issues/1221
- const onwarn = (warning, _onwarn) => (warning.code === "CIRCULAR_DEPENDENCY" && /[/\\]@sapper[/\\]/.test(warning.message)) || warningIsIgnored(warning) || console.warn(warning.toString());
- export default {
- client: {
- input: config.client.input().replace(/\.js$/, ".ts"),
- output: { ...config.client.output() },
- plugins: [
- replace({
- "process.browser": true,
- "process.env.NODE_ENV": JSON.stringify(mode),
- }),
- svelte({
- dev,
- hydratable: true,
- emitCss: true,
- preprocess,
- }),
- resolve({
- browser: true,
- dedupe: ["svelte"],
- }),
- commonjs(),
- typescript(),
- json(),
- legacy && babel({
- extensions: [".js", ".mjs", ".html", ".svelte"],
- babelHelpers: "runtime",
- exclude: ["node_modules/@babel/**"],
- presets: [
- ["@babel/preset-env", {
- targets: "> 0.25%, not dead",
- }],
- ],
- plugins: [
- "@babel/plugin-syntax-dynamic-import",
- ["@babel/plugin-transform-runtime", {
- useESModules: true,
- }],
- ],
- }),
- !dev && terser({
- module: true,
- }),
- ],
- preserveEntrySignatures: false,
- onwarn,
- },
- server: {
- input: { server: config.server.input().server.replace(/\.js$/, ".ts") },
- output: { ...config.server.output(), sourcemap },
- plugins: [
- replace({
- "process.browser": false,
- "process.env.NODE_ENV": JSON.stringify(mode),
- "module.require": "require",
- }),
- svelte({
- generate: "ssr",
- dev,
- preprocess,
- }),
- resolve({
- dedupe: ["svelte"],
- }),
- commonjs(),
- typescript(),
- json(),
- ],
- external: Object.keys(pkg.dependencies).concat(
- require("module").builtinModules || Object.keys(process.binding("natives")), // eslint-disable-line global-require
- ),
- preserveEntrySignatures: "strict",
- onwarn,
- },
- serviceworker: {
- input: config.serviceworker.input().replace(/\.js$/, ".ts"),
- output: config.serviceworker.output(),
- plugins: [
- resolve(),
- replace({
- "process.browser": true,
- "process.env.NODE_ENV": JSON.stringify(mode),
- }),
- commonjs(),
- typescript(),
- !dev && terser(),
- ],
- preserveEntrySignatures: false,
- onwarn,
- },
- };
|