mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2024-12-22 22:21:19 +00:00
6760db9e18
Terser can't handle the static blocks our code produce. SWC can handle this, but causes other problems caused by the global-error files. It's not a nice solution but the benefit is bigger than the risk. Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de>
106 lines
2.5 KiB
JavaScript
106 lines
2.5 KiB
JavaScript
/*
|
|
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
const { isMockMode, isTestMode, isProfilingMode, isBuildTime } = require('./src/utils/test-modes')
|
|
const path = require('path')
|
|
const CopyWebpackPlugin = require('copy-webpack-plugin')
|
|
const withBundleAnalyzer = require('@next/bundle-analyzer')({
|
|
enabled: isProfilingMode
|
|
})
|
|
|
|
console.log('Node environment is', process.env.NODE_ENV)
|
|
|
|
if (isTestMode) {
|
|
console.warn(`This build runs in test mode. This means:
|
|
- No sandboxed iframe
|
|
- Additional data-attributes for e2e tests added to DOM
|
|
- Editor and renderer are running on the same origin
|
|
- No frontend config caching
|
|
`)
|
|
}
|
|
|
|
if (isMockMode) {
|
|
console.warn(`This build runs in mock mode. This means:
|
|
- No real data. All API responses are mocked
|
|
- No persistent data
|
|
- No realtime editing
|
|
`)
|
|
}
|
|
|
|
if (isBuildTime) {
|
|
console.warn(`This process runs in build mode. During build time this means:
|
|
- Editor and Renderer base urls are https://example.org
|
|
- No frontend config will be fetched
|
|
`)
|
|
}
|
|
|
|
if (isProfilingMode) {
|
|
console.info('This build contains the bundle analyzer and profiling metrics.')
|
|
}
|
|
|
|
/** @type {import('@svgr/webpack').LoaderOptions} */
|
|
const svgrConfig = {
|
|
svgoConfig: {
|
|
plugins: [
|
|
{
|
|
name: 'preset-default',
|
|
params: {
|
|
overrides: {
|
|
removeViewBox: false
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
|
|
/** @type {import('next').NextConfig} */
|
|
const rawNextConfig = {
|
|
webpack: (config) => {
|
|
config.module.rules.push({
|
|
test: /\.svg$/i,
|
|
issuer: /\.[jt]sx?$/,
|
|
use: [
|
|
{
|
|
loader: '@svgr/webpack',
|
|
options: svgrConfig
|
|
}
|
|
]
|
|
})
|
|
|
|
const emojiPickerDataModulePath = path.dirname(require.resolve('emoji-picker-element-data/en/emojibase/data.json'))
|
|
|
|
config.plugins.push(
|
|
new CopyWebpackPlugin({
|
|
patterns: [
|
|
{
|
|
from: emojiPickerDataModulePath,
|
|
to: 'static/js/emoji-data.json'
|
|
}
|
|
]
|
|
})
|
|
)
|
|
return config
|
|
},
|
|
reactStrictMode: false,
|
|
redirects: () => {
|
|
return Promise.resolve([
|
|
{
|
|
source: '/',
|
|
destination: '/login',
|
|
permanent: true
|
|
}
|
|
])
|
|
},
|
|
output: 'standalone',
|
|
swcMinify: true,
|
|
experimental: {
|
|
outputFileTracingRoot: path.join(__dirname, '../')
|
|
},
|
|
productionBrowserSourceMaps: true
|
|
}
|
|
const completeNextConfig = withBundleAnalyzer(rawNextConfig)
|
|
|
|
module.exports = completeNextConfig
|