forked from Sagarpreet/Leaflet.FreeDraw
-
Notifications
You must be signed in to change notification settings - Fork 5
/
rollup.config.js
104 lines (101 loc) · 2.3 KB
/
rollup.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import resolve from "rollup-plugin-node-resolve";
import commonjs from "rollup-plugin-commonjs";
import babel from "rollup-plugin-babel";
import { terser } from "rollup-plugin-terser";
import postcss from "rollup-plugin-postcss";
import visualizer from 'rollup-plugin-visualizer';
import pkg from './package.json';
const globals = {
react: 'React',
'react-dom': 'ReactDOM',
leaflet: 'L',
'react-leaflet': 'ReactLeaflet',
ramda: 'R',
'd3-selection': 'd3',
'd3-shape': 'd3'
}
module.exports = {
input: "src/FreeDraw.js",
external: Object.keys(pkg.peerDependencies),
output: [
{
file: "dist/leaflet-freedraw.esm.js",
format: "esm",
sourcemap: true,
exports: 'named',
external: pkg.peerDependencies,
globals
},
{
file: "dist/leaflet-freedraw.web.js",
format: "cjs",
sourcemap: true,
exports: 'named',
name: 'ReactLeafletCraft',
globals
},
{
file: "dist/leaflet-freedraw.iife.js",
format: "iife",
sourcemap: true,
name: 'LeafletFreeDraw',
exports: 'named',
globals
}
],
plugins: [
resolve(),
commonjs({
namedExports: {
'node_modules/leaflet/dist/leaflet-src.js': [
'DomUtil',
'Point',
'DivIcon',
'Marker',
'DomEvent',
'Polygon',
'LineUtil',
'FeatureGroup',
'Control',
'Circle',
'CircleMarker',
'GeoJSON',
'GridLayer',
'ImageOverlay',
'latLngBounds',
'LayerGroup',
'Map',
'Polyline',
'Popup',
'Rectangle',
'SVGOverlay',
'TileLayer',
'Tooltip',
'VideoOverlay',
'Layer'
],
'node_modules/ramda/dist/ramda.js': ['flatten', 'compose', 'head', 'complement', 'identical'],
'node_modules/react/index.js': [
'createContext',
'useContext',
'forwardRef',
'Component',
'Fragment',
'Children',
'cloneElement'
],
'node_modules/react-dom/index.js': [
'createPortal'
],
}
}),
postcss({
plugins: []
}),
babel({
exclude: "node_modules/**"
}),
visualizer(),
terser()
]
};