From d9e7867052bc2297620c36f74ebb86f9389f7cab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?V=C3=ADctor=20Fern=C3=A1ndez=20de=20Alba?= Date: Mon, 9 Dec 2024 17:37:49 +0100 Subject: [PATCH] Fixed circular import error in dev with HMR in core Views and Widgets shadow customizations (#6526) --- packages/volto/news/6526.bugfix | 1 + packages/volto/src/config/Views.jsx | 10 ++++++++++ packages/volto/src/config/Widgets.jsx | 5 +++++ packages/volto/src/config/index.js | 25 ++++++------------------- 4 files changed, 22 insertions(+), 19 deletions(-) create mode 100644 packages/volto/news/6526.bugfix diff --git a/packages/volto/news/6526.bugfix b/packages/volto/news/6526.bugfix new file mode 100644 index 0000000000..0a6496a9d9 --- /dev/null +++ b/packages/volto/news/6526.bugfix @@ -0,0 +1 @@ +Fixed circular import error in dev with HMR in core Views and Widgets shadow customizations. @sneridagh diff --git a/packages/volto/src/config/Views.jsx b/packages/volto/src/config/Views.jsx index bb60818ece..e9aef779dc 100644 --- a/packages/volto/src/config/Views.jsx +++ b/packages/volto/src/config/Views.jsx @@ -138,3 +138,13 @@ export const layoutViewsNamesMapping = { view: 'Default view', default: 'Default view', }; + +export function installDefaultViews(config) { + config.views.layoutViews = layoutViews; + config.views.contentTypesViews = contentTypesViews; + config.views.defaultView = defaultView; + config.views.errorViews = errorViews; + config.views.layoutViewsNamesMapping = layoutViewsNamesMapping; + + return config; +} diff --git a/packages/volto/src/config/Widgets.jsx b/packages/volto/src/config/Widgets.jsx index 07f2a72c57..e4be7ea248 100644 --- a/packages/volto/src/config/Widgets.jsx +++ b/packages/volto/src/config/Widgets.jsx @@ -151,3 +151,8 @@ export const widgetMapping = { // Default Widget export const defaultWidget = TextWidget; + +export function installDefaultWidgets(config) { + config.widgets = widgetMapping; + config.widgets.default = defaultWidget; +} diff --git a/packages/volto/src/config/index.js b/packages/volto/src/config/index.js index cf912fbaf0..48ab6e0159 100644 --- a/packages/volto/src/config/index.js +++ b/packages/volto/src/config/index.js @@ -1,13 +1,5 @@ import ConfigRegistry from '@plone/volto/registry'; import { parse as parseUrl } from 'url'; -import { defaultWidget, widgetMapping } from './Widgets'; -import { - layoutViews, - contentTypesViews, - defaultView, - errorViews, - layoutViewsNamesMapping, -} from './Views'; import { nonContentRoutes } from './NonContentRoutes'; import { nonContentRoutesPublic } from './NonContentRoutesPublic'; import { loadables } from './Loadables'; @@ -26,6 +18,8 @@ import { import applyAddonConfiguration, { addonsInfo } from 'load-volto-addons'; import { installDefaultComponents } from './Components'; +import { installDefaultWidgets } from './Widgets'; +import { installDefaultViews } from './Views'; import { installDefaultBlocks } from './Blocks'; import { getSiteAsyncPropExtender } from '@plone/volto/helpers/Site'; @@ -189,17 +183,8 @@ let config = { enabled: true, }, }, - widgets: { - ...widgetMapping, - default: defaultWidget, - }, - views: { - layoutViews, - contentTypesViews, - defaultView, - errorViews, - layoutViewsNamesMapping, - }, + widgets: {}, + views: {}, blocks: {}, addonRoutes: [], addonReducers: {}, @@ -249,6 +234,8 @@ Object.entries(slots).forEach(([slotName, components]) => { registerValidators(ConfigRegistry); installDefaultComponents(ConfigRegistry); +installDefaultWidgets(ConfigRegistry); +installDefaultViews(ConfigRegistry); installDefaultBlocks(ConfigRegistry); applyAddonConfiguration(ConfigRegistry);