libresign/webpack.config.js
Vitor Mattos fae5dbfa96
feat: implement ckeditor
Signed-off-by: Vitor Mattos <vitor@php.rio>
2025-03-31 10:18:56 -03:00

124 lines
3.3 KiB
JavaScript

/**
* SPDX-FileCopyrightText: 2020-2024 LibreCode coop and contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
const { merge } = require('webpack-merge')
const path = require('path')
const CKEditorWebpackPlugin = require('@ckeditor/ckeditor5-dev-webpack-plugin')
const { styles } = require('@ckeditor/ckeditor5-dev-utils')
const BabelLoaderExcludeNodeModulesExcept = require('babel-loader-exclude-node-modules-except')
const { EsbuildPlugin } = require('esbuild-loader')
const nextcloudWebpackConfig = require('@nextcloud/webpack-vue-config')
const CopyPlugin = require('copy-webpack-plugin');
function getPostCssConfig(ckEditorOpts) {
// CKEditor is not compatbile with postcss@8 and postcss-loader@4 despite stating so.
// Adapted from https://github.com/ckeditor/ckeditor5/issues/8112#issuecomment-960579351
const { plugins, ...rest } = styles.getPostCssConfig(ckEditorOpts);
return { postcssOptions: { plugins }, ...rest };
};
module.exports = merge(nextcloudWebpackConfig, {
entry: {
init: path.resolve(path.join('src', 'init.js')),
tab: path.resolve(path.join('src', 'tab.js')),
settings: path.resolve(path.join('src', 'settings.js')),
external: path.resolve(path.join('src', 'external.js')),
validation: path.resolve(path.join('src', 'validation.js')),
},
optimization: {
splitChunks: {
cacheGroups: {
defaultVendors: {
reuseExistingChunk: true,
},
},
},
minimizer: [
new EsbuildPlugin({
target: 'es2020',
}),
],
},
devServer: {
port: 3000, // use any port suitable for your configuration
host: '0.0.0.0', // to accept connections from outside container
},
output: {
assetModuleFilename: '[name][ext]?v=[contenthash]',
},
module: {
rules: [
{
test: /\.js$/,
loader: 'esbuild-loader',
options: {
// Implicitly set as JS loader for only JS parts of Vue SFCs will be transpiled
loader: 'js',
target: 'es2020',
},
exclude: BabelLoaderExcludeNodeModulesExcept([
'@ckeditor',
'@nextcloud/event-bus',
]),
},
{
test: /\.(ttf|otf|eot|woff|woff2)$/,
type: 'asset/inline',
exclude: /ckeditor5-[^/\\]+[/\\]theme[/\\]icons[/\\][^/\\]+\.svg$/,
},
// Load raw SVGs to be able to inject them via v-html
{
test: /@mdi\/svg/,
type: 'asset/source',
},
{
resourceQuery: /raw/,
type: 'asset/source',
},
{
test: /pdf\.worker(\.min)?\.mjs$/,
type: 'asset/resource'
},
{
test: /ckeditor5-[^/\\]+[/\\]theme[/\\]icons[/\\][^/\\]+\.svg$/,
type: 'asset/source'
},
{
test: /\.(svg)$/i,
use: [
{
loader: 'svg-inline-loader',
},
],
exclude: path.join(__dirname, 'node_modules', '@ckeditor'),
},
{
test: /ckeditor5-[^/\\]+[/\\].+\.css$/,
loader: 'postcss-loader',
options: getPostCssConfig({
themeImporter: {
themePath: require.resolve('@ckeditor/ckeditor5-theme-lark'),
},
minify: true,
}),
},
],
},
cache: true,
plugins: [
// CKEditor needs its own plugin to be built using webpack.
new CKEditorWebpackPlugin({
// See https://ckeditor.com/docs/ckeditor5/latest/features/ui-language.html
language: 'en',
}),
new CopyPlugin({
patterns: [
{
from: 'node_modules/@libresign/vue-pdf-editor/dist/pdf.worker.min.mjs',
to: '',
},
],
}),
],
})