// eslint-disable-next-line @typescript-eslint/no-var-requires const mix = require('laravel-mix'); require('laravel-mix-bundle-analyzer'); /* |-------------------------------------------------------------------------- | Mix Asset Management |-------------------------------------------------------------------------- | | Mix provides a clean, fluent API for defining some Webpack build steps | for your Laravel application. By default, we are compiling the Sass | file for the application as well as bundling up all the JS files. | */ mix.ts('resources/assets/js/app.ts', 'public/js') .ts('resources/assets/js/home.ts', 'public/js') .ts('resources/assets/js/user/profile.ts', 'public/js/user') .ts('resources/assets/js/user/stats.ts', 'public/js/user') .ts('resources/assets/js/setting/privacy.ts', 'public/js/setting') .ts('resources/assets/js/setting/import.ts', 'public/js/setting') .ts('resources/assets/js/setting/deactivate.ts', 'public/js/setting') .ts('resources/assets/js/setting/webhooks.ts', 'public/js/setting') .ts('resources/assets/js/checkin.tsx', 'public/js') .sass('resources/assets/sass/app.scss', 'public/css') .autoload({ jquery: ['$', 'jQuery', 'window.jQuery'], }) .extract(['jquery', 'bootstrap']) .extract(['chart.js', 'chartjs-color', 'color-name', 'moment', 'cal-heatmap', 'd3'], 'public/js/vendor/chart') .version() .sourceMaps(false) .webpackConfig((_webpack) => ({ externals: { moment: 'moment', }, })); if (process.argv.includes('-a')) { mix.bundleAnalyzer({ analyzerMode: 'static' }); }