forked from runme-io/website
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
executable file
·140 lines (126 loc) · 3.61 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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
import resolve from '@rollup/plugin-node-resolve'
import replace from '@rollup/plugin-replace'
import commonjs from '@rollup/plugin-commonjs'
import svelte from 'rollup-plugin-svelte'
import babel from 'rollup-plugin-babel'
import { terser } from 'rollup-plugin-terser'
import config from 'sapper/config/rollup.js'
import pkg from './package.json'
import sveltePreprocess from 'svelte-preprocess'
import { config as dotenvConfig } from 'dotenv'
const mode = process.env.NODE_ENV
const dev = mode === 'development'
const legacy = !!process.env.SAPPER_LEGACY_BUILD
// TODO simplify the way of getting env vars
// setup the correct variables from the .env file for local usage
const { parsed: envVars = {} } = dotenvConfig()
// we also need to check the process env for getting the env var from a docker build command
// e.g. docker build --build-arg RUNME_API_HOST=svc.runme.io
const { parsed = {} } = dotenvConfig({ path: './.env.example' })
Object.keys(parsed)
.filter(key => process.env[key])
.forEach(key => (envVars[key] = process.env[key]))
const {
RUNME_API_HOST = '$RUNME_API_HOST',
RUNME_API_SECURE = '$RUNME_API_SECURE',
DEPLOYMENT_HOST = '$DEPLOYMENT_HOST',
APPLICATION_PROJECT_ID = '$APPLICATION_PROJECT_ID',
API_KEY = '$API_KEY',
API_SECRET = '$API_SECRET',
JEXIA_PROJECT_ZONE = '$JEXIA_PROJECT_ZONE',
} = envVars
const onwarn = (warning, onwarn) => (warning.code === 'CIRCULAR_DEPENDENCY' && /[/\\]@sapper[/\\]/.test(warning.message)) || onwarn(warning)
const preprocess = sveltePreprocess({
scss: {
includePaths: ['src'],
},
postcss: {
plugins: [require('autoprefixer')],
},
})
export default {
client: {
input: config.client.input(),
output: config.client.output(),
plugins: [
replace({
'process.browser': true,
'process.env.NODE_ENV': JSON.stringify(mode),
'runme-api-host': RUNME_API_HOST,
'runme-api-secure': RUNME_API_SECURE,
'deployment-host': DEPLOYMENT_HOST,
'jexia-application-project-id': APPLICATION_PROJECT_ID,
'jexia-api-key': API_KEY,
'jexia-api-secret': API_SECRET,
'jexia-project-zone': JEXIA_PROJECT_ZONE,
}),
svelte({
dev,
hydratable: true,
emitCss: true,
preprocess,
}),
resolve({
preferBuiltins: false,
browser: true,
dedupe: ['svelte'],
}),
commonjs(),
legacy && babel({
extensions: ['.js', '.mjs', '.html', '.svelte'],
runtimeHelpers: true,
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,
}),
],
onwarn,
},
server: {
input: config.server.input(),
output: config.server.output(),
plugins: [
replace({
'process.env.NODE_ENV': JSON.stringify(mode),
}),
svelte({
generate: 'ssr',
dev,
preprocess,
}),
resolve({
dedupe: ['svelte'],
}),
commonjs(),
],
external: Object.keys(pkg.dependencies).concat(
require('module').builtinModules,
),
onwarn,
},
serviceworker: {
input: config.serviceworker.input(),
output: config.serviceworker.output(),
plugins: [
resolve(),
replace({
'process.env.NODE_ENV': JSON.stringify(mode),
}),
commonjs(),
!dev && terser(),
],
onwarn,
},
}