Created
November 24, 2022 02:48
-
-
Save likidu/5d2f0486c6825ca2ad31916c951bf762 to your computer and use it in GitHub Desktop.
Rollup config for building KaiOS v2.5 apps
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import sveltePreprocess from 'svelte-preprocess'; | |
import css from 'rollup-plugin-css-only'; | |
import svelte from 'rollup-plugin-svelte'; | |
import nodePolyfills from 'rollup-plugin-polyfill-node'; | |
import commonjs from '@rollup/plugin-commonjs'; | |
import resolve from '@rollup/plugin-node-resolve'; | |
import terser from '@rollup/plugin-terser'; | |
import typescript from '@rollup/plugin-typescript'; | |
import { babel } from '@rollup/plugin-babel'; | |
import replace from '@rollup/plugin-replace'; | |
// rollup -c -w | |
const production = !process.env.ROLLUP_WATCH; | |
export default { | |
input: 'src/main.ts', | |
output: { | |
sourcemap: !production, | |
format: 'iife', | |
name: 'app', | |
file: 'public/assets/bundle.js', | |
}, | |
context: 'window', | |
plugins: [ | |
replace({ | |
preventAssignment: true, | |
'process.env.NODE_ENV': JSON.stringify(production ? 'production' : 'development'), | |
}), | |
svelte({ | |
preprocess: sveltePreprocess({ | |
sourceMap: !production, | |
postcss: true, | |
typescript: { | |
compilerOptions: { | |
target: 'ES2015', | |
module: 'ES2015', | |
}, | |
}, | |
replace: [[/process\.env\.(\w+)/g, (_, prop) => JSON.stringify(process.env[prop])]], | |
}), | |
compilerOptions: { | |
// enable run-time checks when not in production | |
dev: !production, | |
}, | |
}), | |
// we'll extract any component CSS out into | |
// a separate file - better for performance | |
css({ output: 'bundle.css' }), | |
nodePolyfills(), | |
babel({ | |
extensions: ['.js', '.ts', '.html', '.svelte'], | |
babelHelpers: 'runtime', | |
exclude: ['node_modules/@babel/**'], | |
presets: [ | |
[ | |
'@babel/preset-env', | |
{ | |
targets: { firefox: '48' }, | |
exclude: ['@babel/plugin-transform-regenerator'], | |
}, | |
], | |
], | |
plugins: [ | |
'@babel/plugin-syntax-dynamic-import', | |
[ | |
'@babel/plugin-transform-runtime', | |
{ | |
useESModules: true, | |
regenerator: false, | |
}, | |
], | |
], | |
}), | |
replace({ | |
preventAssignment: true, | |
'process.env.NODE_ENV': !production ? "'development'" : "'production'", | |
}), | |
// 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/plugins/tree/master/packages/commonjs | |
resolve({ | |
browser: true, | |
dedupe: ['svelte'], | |
}), | |
commonjs(), | |
typescript({ | |
sourceMap: !production, | |
inlineSources: !production, | |
}), | |
// If we're building for production (npm run build | |
// instead of npm run dev), minify | |
production && terser(), | |
], | |
}; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment