From 8da8c404ec872200219c2dbc435ed3a021a99d51 Mon Sep 17 00:00:00 2001 From: Louis Chemineau Date: Thu, 24 Aug 2023 10:50:21 +0200 Subject: [PATCH 1/3] Lazy load text-viewer and text-files + Remove vendor bundling + Remove chunkIds declaration as it is already the default + Group mermaid chunks Signed-off-by: Louis Chemineau --- src/files.js | 16 +++++++++++----- src/helpers/files.js | 5 +++-- src/viewer.js | 1 + webpack.config.js | 16 +++++++++++----- 4 files changed, 26 insertions(+), 12 deletions(-) diff --git a/src/files.js b/src/files.js index 0b156bd0504..94c2d9d05d8 100644 --- a/src/files.js +++ b/src/files.js @@ -21,12 +21,9 @@ */ import { linkTo } from '@nextcloud/router' import { loadState } from '@nextcloud/initial-state' -import Vue from 'vue' +import { registerFileListHeaders } from '@nextcloud/files' import { logger } from './helpers/logger.js' -import { registerFileActionFallback } from './helpers/files.js' -import FilesSettings from './views/FilesSettings.vue' -import store from './store/index.js' __webpack_nonce__ = window.btoa(OC.requestToken) // eslint-disable-line __webpack_public_path__ = linkTo('text', 'js/') // eslint-disable-line @@ -34,13 +31,18 @@ __webpack_public_path__ = linkTo('text', 'js/') // eslint-disable-line const workspaceAvailable = loadState('text', 'workspace_available') const workspaceEnabled = loadState('text', 'workspace_enabled') -document.addEventListener('DOMContentLoaded', () => { +document.addEventListener('DOMContentLoaded', async () => { if (typeof OCA.Viewer === 'undefined') { + const { registerFileActionFallback } = await import('./helpers/files.js') logger.error('Viewer app is not installed') registerFileActionFallback() } if (workspaceAvailable && OCA && OCA?.Files?.Settings) { + const { default: Vue } = await import('vue') + const { default: FilesSettings } = await import('./views/FilesSettings.vue') + const { default: store } = await import('./store/index.js') + Vue.prototype.t = window.t Vue.prototype.n = window.n Vue.prototype.OCA = window.OCA @@ -54,6 +56,10 @@ document.addEventListener('DOMContentLoaded', () => { })) } + if (workspaceAvailable) { + const { FilesWorkspaceHeader } = await import('./helpers/files.js') + registerFileListHeaders(FilesWorkspaceHeader) + } }) OCA.Text = { diff --git a/src/helpers/files.js b/src/helpers/files.js index 1985c2c6acb..a5ca85fddb3 100644 --- a/src/helpers/files.js +++ b/src/helpers/files.js @@ -27,7 +27,6 @@ import { loadState } from '@nextcloud/initial-state' import { getSharingToken } from './token.js' import { openMimetypes } from './mime.js' -import RichWorkspace from '../views/RichWorkspace.vue' import store from '../store/index.js' import { getCurrentUser } from '@nextcloud/auth' import { showSuccess, showError } from '@nextcloud/dialogs' @@ -211,7 +210,7 @@ export const FilesWorkspaceHeader = new Header({ return view.id === 'files' }, - render(el, folder, view) { + async render(el, folder, view) { if (vm) { // Enforce destroying of the old rendering and rerender as the FilesListHeader calls render on every folder change vm.$destroy() @@ -223,6 +222,8 @@ export const FilesWorkspaceHeader = new Header({ newWorkspaceCreated = false + const { default: RichWorkspace } = await import('./../views/RichWorkspace.vue') + import('vue').then((module) => { el.id = 'files-workspace-wrapper' diff --git a/src/viewer.js b/src/viewer.js index f66559b07ab..290cabe91d7 100644 --- a/src/viewer.js +++ b/src/viewer.js @@ -33,6 +33,7 @@ if (typeof OCA.Viewer === 'undefined') { OCA.Viewer.registerHandler({ id: 'text', mimes: [...openMimetypesMarkdown, ...openMimetypesPlainText], + // Would be good to be able to lazyload that component: ViewerComponent, group: null, theme: 'default', diff --git a/webpack.config.js b/webpack.config.js index 83164a1f2bd..0e1ce066064 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -45,11 +45,6 @@ webpackConfig.optimization.splitChunks.cacheGroups = { } } -// webpackConfig.resolve.modules = [ -// path.resolve(__dirname, 'node_modules'), -// 'node_modules' -// ] - // Fix Buffer issues webpackConfig.plugins.push(new webpack.ProvidePlugin({ Buffer: ['buffer', 'Buffer'], @@ -67,4 +62,15 @@ webpackRules.RULE_RAW_SVGS = { webpackConfig.module.rules = Object.values(webpackRules) +webpackConfig.optimization.splitChunks.minSize = 102400 + +webpackConfig.optimization.splitChunks.cacheGroups = { + mermaid: { + test(module) { + return module.resource && module.resource.includes(`${path.sep}node_modules${path.sep}mermaid`) + }, + name: 'mermaid', + }, +} + module.exports = webpackConfig From 8409b5a0543607c0900559832623e7e3ca000f5d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julius=20H=C3=A4rtl?= Date: Tue, 28 Nov 2023 09:30:39 +0100 Subject: [PATCH 2/3] fix: Lazy load viewer component MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- src/viewer.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/viewer.js b/src/viewer.js index 290cabe91d7..b6c43b2cf1b 100644 --- a/src/viewer.js +++ b/src/viewer.js @@ -20,7 +20,6 @@ * */ -import ViewerComponent from './components/ViewerComponent.vue' import { logger } from './helpers/logger.js' import { openMimetypesMarkdown, openMimetypesPlainText } from './helpers/mime.js' @@ -33,8 +32,7 @@ if (typeof OCA.Viewer === 'undefined') { OCA.Viewer.registerHandler({ id: 'text', mimes: [...openMimetypesMarkdown, ...openMimetypesPlainText], - // Would be good to be able to lazyload that - component: ViewerComponent, + component: () => import('./components/ViewerComponent.vue'), group: null, theme: 'default', canCompare: true, From b9009dc9f6663eee2de470368f0ff2006b037e0c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julius=20H=C3=A4rtl?= Date: Tue, 28 Nov 2023 09:47:44 +0100 Subject: [PATCH 3/3] fix: Merge webpack splitChunks options MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- webpack.config.js | 23 +++++------------------ 1 file changed, 5 insertions(+), 18 deletions(-) diff --git a/webpack.config.js b/webpack.config.js index 0e1ce066064..914689eec82 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -36,14 +36,12 @@ Object.assign(webpackConfig.output, { webpackConfig.optimization.chunkIds = 'named' webpackConfig.optimization.splitChunks.cacheGroups = { - defaultVendors: { - test(module) { - return module.resource && module.resource.includes(`${path.sep}node_modules${path.sep}`) && - !module.resource.includes(`${path.sep}highlight.js${path.sep}`) - }, - name: 'vendors', - } + mermaid: { + test: /[\\/]node_modules[\\/](mermaid)[\\/]/, + name: 'mermaid', + }, } +webpackConfig.optimization.splitChunks.minSize = 102400 // Fix Buffer issues webpackConfig.plugins.push(new webpack.ProvidePlugin({ @@ -62,15 +60,4 @@ webpackRules.RULE_RAW_SVGS = { webpackConfig.module.rules = Object.values(webpackRules) -webpackConfig.optimization.splitChunks.minSize = 102400 - -webpackConfig.optimization.splitChunks.cacheGroups = { - mermaid: { - test(module) { - return module.resource && module.resource.includes(`${path.sep}node_modules${path.sep}mermaid`) - }, - name: 'mermaid', - }, -} - module.exports = webpackConfig