262 lines
5.5 KiB
JavaScript
262 lines
5.5 KiB
JavaScript
import typescript from 'rollup-plugin-typescript2';
|
|
import esbuild from 'rollup-plugin-esbuild';
|
|
import resolve from '@rollup/plugin-node-resolve';
|
|
import postcss from 'rollup-plugin-postcss';
|
|
import renameNodeModules from 'rollup-plugin-rename-node-modules';
|
|
import webWorkerLoader from 'rollup-plugin-web-worker-loader';
|
|
import pkg from './package.json';
|
|
|
|
function toRecordPath(path) {
|
|
return path
|
|
.replace(/^([\w]+)\//, '$1/record/')
|
|
.replace('rrweb', 'rrweb-record');
|
|
}
|
|
|
|
function toRecordPackPath(path) {
|
|
return path
|
|
.replace(/^([\w]+)\//, '$1/record/')
|
|
.replace('rrweb', 'rrweb-record-pack');
|
|
}
|
|
|
|
function toReplayPath(path) {
|
|
return path
|
|
.replace(/^([\w]+)\//, '$1/replay/')
|
|
.replace('rrweb', 'rrweb-replay');
|
|
}
|
|
|
|
function toReplayUnpackPath(path) {
|
|
return path
|
|
.replace(/^([\w]+)\//, '$1/replay/')
|
|
.replace('rrweb', 'rrweb-replay-unpack');
|
|
}
|
|
|
|
function toAllPath(path) {
|
|
return path.replace('rrweb', 'rrweb-all');
|
|
}
|
|
|
|
function toPluginPath(pluginName, stage) {
|
|
return (path) =>
|
|
path
|
|
.replace(/^([\w]+)\//, '$1/plugins/')
|
|
.replace('rrweb', `${pluginName}-${stage}`);
|
|
}
|
|
|
|
function toMinPath(path) {
|
|
return path.replace(/\.js$/, '.min.js');
|
|
}
|
|
|
|
const baseConfigs = [
|
|
// all in one
|
|
{
|
|
input: './src/entries/all.ts',
|
|
name: 'rrweb',
|
|
pathFn: toAllPath,
|
|
esm: true,
|
|
},
|
|
// record only
|
|
{
|
|
input: './src/record/index.ts',
|
|
name: 'rrwebRecord',
|
|
pathFn: toRecordPath,
|
|
},
|
|
// record and pack
|
|
{
|
|
input: './src/entries/record-pack.ts',
|
|
name: 'rrwebRecord',
|
|
pathFn: toRecordPackPath,
|
|
},
|
|
// replay only
|
|
{
|
|
input: './src/replay/index.ts',
|
|
name: 'rrwebReplay',
|
|
pathFn: toReplayPath,
|
|
},
|
|
// replay and unpack
|
|
{
|
|
input: './src/entries/replay-unpack.ts',
|
|
name: 'rrwebReplay',
|
|
pathFn: toReplayUnpackPath,
|
|
},
|
|
// record and replay
|
|
{
|
|
input: './src/index.ts',
|
|
name: 'rrweb',
|
|
pathFn: (p) => p,
|
|
},
|
|
// plugins
|
|
{
|
|
input: './src/plugins/console/record/index.ts',
|
|
name: 'rrwebConsoleRecord',
|
|
pathFn: toPluginPath('console', 'record'),
|
|
},
|
|
{
|
|
input: './src/plugins/canvas-webrtc/record/index.ts',
|
|
name: 'rrwebCanvasWebRTCRecord',
|
|
pathFn: toPluginPath('canvas-webrtc', 'record'),
|
|
},
|
|
{
|
|
input: './src/plugins/canvas-webrtc/replay/index.ts',
|
|
name: 'rrwebCanvasWebRTCReplay',
|
|
pathFn: toPluginPath('canvas-webrtc', 'replay'),
|
|
},
|
|
{
|
|
input: './src/plugins/console/replay/index.ts',
|
|
name: 'rrwebConsoleReplay',
|
|
pathFn: toPluginPath('console', 'replay'),
|
|
},
|
|
{
|
|
input: './src/plugins/sequential-id/record/index.ts',
|
|
name: 'rrwebSequentialIdRecord',
|
|
pathFn: toPluginPath('sequential-id', 'record'),
|
|
},
|
|
{
|
|
input: './src/plugins/sequential-id/replay/index.ts',
|
|
name: 'rrwebSequentialIdReplay',
|
|
pathFn: toPluginPath('sequential-id', 'replay'),
|
|
},
|
|
];
|
|
|
|
let configs = [];
|
|
|
|
function getPlugins(options = {}) {
|
|
const { minify = false, sourceMap = false } = options;
|
|
return [
|
|
resolve({ browser: true }),
|
|
webWorkerLoader({
|
|
targetPlatform: 'browser',
|
|
inline: true,
|
|
preserveSource: true,
|
|
sourceMap,
|
|
}),
|
|
esbuild({
|
|
minify,
|
|
}),
|
|
postcss({
|
|
extract: true,
|
|
inject: false,
|
|
minimize: minify,
|
|
sourceMap,
|
|
}),
|
|
];
|
|
}
|
|
|
|
for (const c of baseConfigs) {
|
|
const basePlugins = [
|
|
resolve({ browser: true }),
|
|
|
|
// supports bundling `web-worker:..filename`
|
|
webWorkerLoader({
|
|
targetPlatform: 'browser',
|
|
inline: true,
|
|
preserveSource: true,
|
|
}),
|
|
|
|
typescript(),
|
|
];
|
|
const plugins = basePlugins.concat(
|
|
postcss({
|
|
extract: false,
|
|
inject: false,
|
|
}),
|
|
);
|
|
// browser
|
|
configs.push({
|
|
input: c.input,
|
|
plugins: getPlugins(),
|
|
output: [
|
|
{
|
|
name: c.name,
|
|
format: 'iife',
|
|
file: c.pathFn(pkg.unpkg),
|
|
},
|
|
],
|
|
});
|
|
// browser + minify
|
|
configs.push({
|
|
input: c.input,
|
|
plugins: getPlugins({ minify: true, sourceMap: true }),
|
|
output: [
|
|
{
|
|
name: c.name,
|
|
format: 'iife',
|
|
file: toMinPath(c.pathFn(pkg.unpkg)),
|
|
sourcemap: true,
|
|
},
|
|
],
|
|
});
|
|
// CommonJS
|
|
configs.push({
|
|
input: c.input,
|
|
plugins,
|
|
output: [
|
|
{
|
|
format: 'cjs',
|
|
file: c.pathFn('lib/rrweb.cjs'),
|
|
},
|
|
],
|
|
});
|
|
if (c.esm) {
|
|
// ES module
|
|
configs.push({
|
|
input: c.input,
|
|
plugins,
|
|
preserveModules: true,
|
|
output: [
|
|
{
|
|
format: 'esm',
|
|
dir: 'es/rrweb',
|
|
plugins: [renameNodeModules('ext')],
|
|
},
|
|
],
|
|
});
|
|
}
|
|
}
|
|
|
|
if (process.env.BROWSER_ONLY) {
|
|
const browserOnlyBaseConfigs = [
|
|
{
|
|
input: './src/index.ts',
|
|
name: 'rrweb',
|
|
pathFn: (p) => p,
|
|
},
|
|
{
|
|
input: './src/entries/all.ts',
|
|
name: 'rrweb',
|
|
pathFn: toAllPath,
|
|
},
|
|
{
|
|
input: './src/plugins/console/record/index.ts',
|
|
name: 'rrwebConsoleRecord',
|
|
pathFn: toPluginPath('console', 'record'),
|
|
},
|
|
{
|
|
input: './src/plugins/canvas-webrtc/record/index.ts',
|
|
name: 'rrwebCanvasWebRTCRecord',
|
|
pathFn: toPluginPath('canvas-webrtc', 'record'),
|
|
},
|
|
{
|
|
input: './src/plugins/canvas-webrtc/replay/index.ts',
|
|
name: 'rrwebCanvasWebRTCReplay',
|
|
pathFn: toPluginPath('canvas-webrtc', 'replay'),
|
|
},
|
|
];
|
|
|
|
configs = [];
|
|
|
|
for (const c of browserOnlyBaseConfigs) {
|
|
configs.push({
|
|
input: c.input,
|
|
plugins: getPlugins(),
|
|
output: [
|
|
{
|
|
name: c.name,
|
|
format: 'iife',
|
|
file: c.pathFn(pkg.unpkg),
|
|
},
|
|
],
|
|
});
|
|
}
|
|
}
|
|
|
|
export default configs;
|