moved rrweb-player into packages/rrweb-player
This commit is contained in:
110
packages/rrweb-player/rollup.config.js
Normal file
110
packages/rrweb-player/rollup.config.js
Normal file
@@ -0,0 +1,110 @@
|
||||
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 sveltePreprocess from 'svelte-preprocess';
|
||||
import typescript from '@rollup/plugin-typescript';
|
||||
import pkg from './package.json';
|
||||
import css from 'rollup-plugin-css-only';
|
||||
|
||||
// eslint-disable-next-line no-undef
|
||||
const production = !process.env.ROLLUP_WATCH;
|
||||
|
||||
const entries = (production
|
||||
? [
|
||||
{ file: pkg.module, format: 'es', css: false },
|
||||
{ file: pkg.main, format: 'cjs', css: false },
|
||||
{
|
||||
file: pkg.unpkg,
|
||||
format: 'iife',
|
||||
name: 'rrwebPlayer',
|
||||
css: 'style.css',
|
||||
},
|
||||
]
|
||||
: []
|
||||
).concat([
|
||||
{
|
||||
file: 'public/bundle.js',
|
||||
format: 'iife',
|
||||
name: 'rrwebPlayer',
|
||||
css: 'bundle.css',
|
||||
},
|
||||
]);
|
||||
|
||||
export default entries.map((output) => ({
|
||||
input: 'src/main.ts',
|
||||
output: {
|
||||
file: output.file,
|
||||
format: output.format,
|
||||
name: output.name,
|
||||
sourcemap: true,
|
||||
exports: 'auto',
|
||||
},
|
||||
plugins: [
|
||||
svelte({
|
||||
compilerOptions: {
|
||||
// enable run-time checks when not in production
|
||||
dev: !production,
|
||||
},
|
||||
preprocess: sveltePreprocess({
|
||||
postcss: {
|
||||
// eslint-disable-next-line no-undef
|
||||
plugins: [require('postcss-easy-import')],
|
||||
},
|
||||
}),
|
||||
}),
|
||||
|
||||
// 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: ['svelte'],
|
||||
}),
|
||||
commonjs(),
|
||||
|
||||
typescript(),
|
||||
|
||||
css({
|
||||
// we'll extract any component CSS out into
|
||||
// a separate file — better for performance
|
||||
output: output.css,
|
||||
}),
|
||||
|
||||
// In dev mode, call `npm run start` once
|
||||
// the bundle has been generated
|
||||
!production && serve(),
|
||||
|
||||
// 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,
|
||||
},
|
||||
}));
|
||||
|
||||
function serve() {
|
||||
let started = false;
|
||||
|
||||
return {
|
||||
writeBundle() {
|
||||
if (!started) {
|
||||
started = true;
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/no-var-requires, no-undef
|
||||
require('child_process').spawn('npm', ['run', 'start', '--', '--dev'], {
|
||||
stdio: ['ignore', 'inherit', 'inherit'],
|
||||
shell: true,
|
||||
});
|
||||
}
|
||||
},
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user