@plone/volto 17.0.0-alpha.2 → 17.0.0-alpha.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (297) hide show
  1. package/.yarn/install-state.gz +0 -0
  2. package/CHANGELOG.md +530 -15
  3. package/CONTRIBUTING.md +1 -1
  4. package/README.md +11 -14
  5. package/addon-registry.js +34 -0
  6. package/create-theme-addons-loader.js +79 -0
  7. package/cypress/support/commands.js +56 -4
  8. package/cypress/support/volto-slate.js +4 -5
  9. package/docker-compose.yml +1 -1
  10. package/locales/ca/LC_MESSAGES/volto.po +272 -6
  11. package/locales/ca.json +1 -1
  12. package/locales/de/LC_MESSAGES/volto.po +291 -25
  13. package/locales/de.json +1 -1
  14. package/locales/en/LC_MESSAGES/volto.po +271 -5
  15. package/locales/en.json +1 -1
  16. package/locales/es/LC_MESSAGES/volto.po +281 -15
  17. package/locales/es.json +1 -1
  18. package/locales/eu/LC_MESSAGES/volto.po +272 -6
  19. package/locales/eu.json +1 -1
  20. package/locales/fi/LC_MESSAGES/volto.po +4882 -0
  21. package/locales/fi.json +1 -1
  22. package/locales/fr/LC_MESSAGES/volto.po +272 -6
  23. package/locales/fr.json +1 -1
  24. package/locales/it/LC_MESSAGES/volto.po +273 -7
  25. package/locales/it.json +1 -1
  26. package/locales/ja/LC_MESSAGES/volto.po +272 -6
  27. package/locales/ja.json +1 -1
  28. package/locales/nl/LC_MESSAGES/volto.po +927 -649
  29. package/locales/nl.json +1 -1
  30. package/locales/pt/LC_MESSAGES/volto.po +272 -6
  31. package/locales/pt.json +1 -1
  32. package/locales/pt_BR/LC_MESSAGES/volto.po +281 -15
  33. package/locales/pt_BR.json +1 -1
  34. package/locales/ro/LC_MESSAGES/volto.po +272 -6
  35. package/locales/ro.json +1 -1
  36. package/locales/volto.pot +272 -6
  37. package/locales/zh_CN/LC_MESSAGES/volto.po +272 -6
  38. package/locales/zh_CN.json +1 -1
  39. package/package.json +5 -3
  40. package/packages/volto-slate/build/messages/src/blocks/Table/TableBlockEdit.json +1 -1
  41. package/packages/volto-slate/build/messages/src/blocks/Text/DefaultTextBlockEditor.json +1 -1
  42. package/packages/volto-slate/build/messages/src/blocks/Text/DetachedTextBlockEditor.json +1 -1
  43. package/packages/volto-slate/build/messages/src/blocks/Text/SlashMenu.json +1 -1
  44. package/packages/volto-slate/build/messages/src/editor/plugins/AdvancedLink/index.json +1 -1
  45. package/packages/volto-slate/build/messages/src/editor/plugins/Link/index.json +1 -1
  46. package/packages/volto-slate/build/messages/src/editor/plugins/Table/index.json +1 -1
  47. package/packages/volto-slate/build/messages/src/elementEditor/messages.json +1 -1
  48. package/packages/volto-slate/build/messages/src/widgets/HtmlSlateWidget.json +1 -1
  49. package/packages/volto-slate/build/messages/src/widgets/RichTextWidgetView.json +1 -1
  50. package/packages/volto-slate/package.json +1 -1
  51. package/packages/volto-slate/src/actions/index.js +1 -1
  52. package/packages/volto-slate/src/blocks/Table/TableBlockEdit.jsx +21 -212
  53. package/packages/volto-slate/src/blocks/Table/schema.js +122 -0
  54. package/packages/volto-slate/src/blocks/Text/DefaultTextBlockEditor.jsx +8 -3
  55. package/packages/volto-slate/src/blocks/Text/SlashMenu.jsx +4 -3
  56. package/packages/volto-slate/src/blocks/Text/TextBlockView.jsx +20 -16
  57. package/packages/volto-slate/src/blocks/Text/extensions/withDeserializers.js +3 -1
  58. package/packages/volto-slate/src/blocks/Text/index.js +10 -2
  59. package/packages/volto-slate/src/editor/config.jsx +5 -4
  60. package/packages/volto-slate/src/editor/deserialize.js +0 -1
  61. package/packages/volto-slate/src/editor/index.js +4 -4
  62. package/packages/volto-slate/src/editor/less/slate.less +28 -0
  63. package/packages/volto-slate/src/editor/plugins/StyleMenu/StyleMenu.jsx +14 -4
  64. package/packages/volto-slate/src/editor/plugins/StyleMenu/utils.js +14 -5
  65. package/packages/volto-slate/src/editor/render.jsx +68 -8
  66. package/packages/volto-slate/src/editor/ui/SlateContextToolbar.jsx +2 -2
  67. package/packages/volto-slate/src/editor/ui/index.js +15 -15
  68. package/packages/volto-slate/src/index.js +2 -2
  69. package/packages/volto-slate/src/utils/blocks.js +7 -0
  70. package/packages/volto-slate/src/widgets/RichTextWidget.jsx +15 -8
  71. package/razzle.config.js +28 -0
  72. package/src/actions/index.js +6 -0
  73. package/src/actions/language/language.js +9 -8
  74. package/src/actions/querystringsearch/querystringsearch.js +20 -14
  75. package/src/actions/relations/rebuild.js +25 -0
  76. package/src/actions/relations/relations.js +86 -0
  77. package/src/actions/relations/relations.test.js +15 -0
  78. package/src/components/index.js +2 -0
  79. package/src/components/manage/Add/Add.jsx +2 -2
  80. package/src/components/manage/AnchorPlugin/index.jsx +2 -2
  81. package/src/components/manage/AnchorPlugin/utils/EditorUtils.js +3 -1
  82. package/src/components/manage/BlockChooser/BlockChooser.jsx +14 -5
  83. package/src/components/manage/BlockChooser/BlockChooser.test.jsx +5 -0
  84. package/src/components/manage/Blocks/Block/BlocksForm.jsx +19 -2
  85. package/src/components/manage/Blocks/Block/Edit.jsx +1 -1
  86. package/src/components/manage/Blocks/Block/Style.jsx +2 -2
  87. package/src/components/manage/Blocks/Container/Data.jsx +32 -0
  88. package/src/components/manage/Blocks/Container/Edit.jsx +174 -0
  89. package/src/components/manage/Blocks/Container/EditBlockWrapper.jsx +120 -0
  90. package/src/components/manage/Blocks/Container/NewBlockAddButton.jsx +84 -0
  91. package/src/components/manage/Blocks/Container/SimpleContainerToolbar.jsx +54 -0
  92. package/src/components/manage/Blocks/Grid/Edit.jsx +33 -0
  93. package/src/components/manage/Blocks/Grid/View.jsx +43 -0
  94. package/src/components/manage/Blocks/Grid/adapter.js +14 -0
  95. package/src/components/manage/Blocks/Grid/grid-1.svg +6 -0
  96. package/src/components/manage/Blocks/Grid/grid-2.svg +9 -0
  97. package/src/components/manage/Blocks/Grid/grid-3.svg +10 -0
  98. package/src/components/manage/Blocks/Grid/grid-4.svg +11 -0
  99. package/src/components/manage/Blocks/Grid/schema.js +35 -0
  100. package/src/components/manage/Blocks/Grid/templates.js +47 -0
  101. package/src/components/manage/Blocks/HeroImageLeft/Edit.jsx +6 -1
  102. package/src/components/manage/Blocks/Image/Edit.jsx +11 -7
  103. package/src/components/manage/Blocks/Image/ImageSidebar.jsx +2 -1
  104. package/src/components/manage/Blocks/Image/schema.js +11 -0
  105. package/src/components/manage/Blocks/Listing/DefaultTemplate.jsx +18 -3
  106. package/src/components/manage/Blocks/Listing/Edit.jsx +0 -14
  107. package/src/components/manage/Blocks/Listing/ListingBody.jsx +30 -8
  108. package/src/components/manage/Blocks/Listing/ListingBody.test.jsx +20 -0
  109. package/src/components/manage/Blocks/Listing/getAsyncData.js +9 -3
  110. package/src/components/manage/Blocks/Listing/withQuerystringResults.jsx +26 -18
  111. package/src/components/manage/Blocks/Search/SearchBlockEdit.jsx +5 -4
  112. package/src/components/manage/Blocks/Search/SearchBlockView.jsx +2 -1
  113. package/src/components/manage/Blocks/Search/components/DateRangeFacet.jsx +4 -1
  114. package/src/components/manage/Blocks/Search/components/Facets.jsx +64 -4
  115. package/src/components/manage/Blocks/Search/components/SearchInput.jsx +9 -2
  116. package/src/components/manage/Blocks/Search/components/index.js +13 -13
  117. package/src/components/manage/Blocks/Search/hocs/index.js +2 -2
  118. package/src/components/manage/Blocks/Search/hocs/withQueryString.jsx +2 -2
  119. package/src/components/manage/Blocks/Search/hocs/withSearch.jsx +43 -15
  120. package/src/components/manage/Blocks/Search/layout/LeftColumnFacets.jsx +17 -5
  121. package/src/components/manage/Blocks/Search/layout/RightColumnFacets.jsx +17 -5
  122. package/src/components/manage/Blocks/Search/layout/TopSideFacets.jsx +21 -5
  123. package/src/components/manage/Blocks/Search/schema.js +16 -1
  124. package/src/components/manage/Blocks/Teaser/Body.jsx +0 -1
  125. package/src/components/manage/Blocks/Teaser/DefaultBody.jsx +20 -15
  126. package/src/components/manage/Blocks/Teaser/schema.js +5 -0
  127. package/src/components/manage/Blocks/Title/View.jsx +15 -5
  128. package/src/components/manage/Blocks/Title/View.test.jsx +16 -1
  129. package/src/components/manage/Blocks/ToC/Schema.jsx +5 -1
  130. package/src/components/manage/Blocks/ToC/View.jsx +8 -1
  131. package/src/components/manage/Blocks/ToC/variations/DefaultTocRenderer.jsx +17 -4
  132. package/src/components/manage/Blocks/ToC/variations/HorizontalMenu.jsx +148 -10
  133. package/src/components/manage/Blocks/ToC/variations/index.js +3 -1
  134. package/src/components/manage/Contents/Contents.jsx +39 -26
  135. package/src/components/manage/Contents/ContentsItem.jsx +6 -0
  136. package/src/components/manage/Contents/ContentsUploadModal.jsx +10 -5
  137. package/src/components/manage/Controlpanels/AddonsControlpanel.jsx +3 -3
  138. package/src/components/manage/Controlpanels/Controlpanels.jsx +199 -224
  139. package/src/components/manage/Controlpanels/Controlpanels.test.jsx +46 -7
  140. package/src/components/manage/Controlpanels/Relations/BrokenRelations.jsx +66 -0
  141. package/src/components/manage/Controlpanels/Relations/Relations.jsx +114 -0
  142. package/src/components/manage/Controlpanels/Relations/RelationsListing.jsx +479 -0
  143. package/src/components/manage/Controlpanels/Relations/RelationsMatrix.jsx +531 -0
  144. package/src/components/manage/Controlpanels/Users/UserGroupMembershipControlPanel.jsx +3 -3
  145. package/src/components/manage/Controlpanels/Users/UserGroupMembershipListing.jsx +51 -82
  146. package/src/components/manage/Controlpanels/Users/UserGroupMembershipMatrix.jsx +79 -75
  147. package/src/components/manage/DragDropList/DragDropList.jsx +18 -13
  148. package/src/components/manage/Form/Form.jsx +5 -3
  149. package/src/components/manage/Form/InlineForm.jsx +39 -9
  150. package/src/components/manage/Form/InlineFormState.js +8 -0
  151. package/src/components/manage/History/History.jsx +11 -1
  152. package/src/components/manage/LinksToItem/LinksToItem.jsx +209 -0
  153. package/src/components/manage/LinksToItem/LinksToItem.test.jsx +97 -0
  154. package/src/components/manage/Multilingual/CreateTranslation.jsx +2 -2
  155. package/src/components/manage/Multilingual/TranslationObject.jsx +4 -3
  156. package/src/components/manage/Preferences/ChangePassword.jsx +2 -2
  157. package/src/components/manage/Preferences/PersonalPreferences.jsx +2 -2
  158. package/src/components/manage/Sharing/Sharing.jsx +5 -1
  159. package/src/components/manage/TemplateChooser/TemplateChooser.jsx +38 -0
  160. package/src/components/manage/TemplateChooser/TemplateChooser.test.jsx +34 -0
  161. package/src/components/manage/TemplateChooser/template.svg +10 -0
  162. package/src/components/manage/Toast/Toast.jsx +2 -2
  163. package/src/components/manage/Toolbar/More.jsx +15 -0
  164. package/src/components/manage/Toolbar/Types.jsx +2 -2
  165. package/src/components/manage/UniversalLink/UniversalLink.jsx +2 -6
  166. package/src/components/manage/UniversalLink/UniversalLink.test.jsx +36 -0
  167. package/src/components/manage/Widgets/ColorPickerWidget.jsx +6 -1
  168. package/src/components/manage/Widgets/DatetimeWidget.jsx +9 -5
  169. package/src/components/manage/Widgets/FileWidget.jsx +2 -1
  170. package/src/components/manage/Widgets/ObjectListWidget.jsx +3 -8
  171. package/src/components/manage/Widgets/RecurrenceWidget/ByDayField.jsx +2 -1
  172. package/src/components/manage/Widgets/RecurrenceWidget/MonthOfTheYearField.jsx +2 -1
  173. package/src/components/manage/Widgets/RecurrenceWidget/Occurences.jsx +2 -1
  174. package/src/components/manage/Widgets/RecurrenceWidget/RecurrenceWidget.jsx +8 -3
  175. package/src/components/manage/Widgets/RecurrenceWidget/WeekdayOfTheMonthField.jsx +2 -1
  176. package/src/components/manage/Widgets/SelectUtils.js +1 -1
  177. package/src/components/manage/Widgets/SelectWidget.jsx +1 -1
  178. package/src/components/theme/Anontools/Anontools.jsx +44 -72
  179. package/src/components/theme/Anontools/Anontools.stories.jsx +16 -6
  180. package/src/components/theme/Anontools/Anontools.test.jsx +16 -2
  181. package/src/components/theme/Breadcrumbs/Breadcrumbs.jsx +52 -99
  182. package/src/components/theme/Breadcrumbs/Breadcrumbs.stories.jsx +14 -13
  183. package/src/components/theme/Comments/CommentEditModal.jsx +63 -115
  184. package/src/components/theme/Component/Component.jsx +1 -1
  185. package/src/components/theme/ContactForm/ContactForm.jsx +108 -192
  186. package/src/components/theme/ContactForm/ContactForm.stories.jsx +1 -1
  187. package/src/components/theme/ContactForm/ContactForm.test.jsx +2 -3
  188. package/src/components/theme/Footer/Footer.jsx +2 -13
  189. package/src/components/theme/Header/Header.jsx +37 -63
  190. package/src/components/theme/Header/Header.test.jsx +18 -0
  191. package/src/components/theme/Icon/Icon.jsx +2 -2
  192. package/src/components/theme/LanguageSelector/LanguageSelector.js +8 -3
  193. package/src/components/theme/Login/Login.jsx +1 -0
  194. package/src/components/theme/Logo/Logo.jsx +2 -1
  195. package/src/components/theme/MultilingualRedirector/MultilingualRedirector.jsx +2 -2
  196. package/src/components/theme/Navigation/NavItem.jsx +4 -2
  197. package/src/components/theme/NotFound/NotFound.jsx +55 -41
  198. package/src/components/theme/PasswordReset/PasswordReset.jsx +7 -4
  199. package/src/components/theme/PasswordReset/RequestPasswordReset.jsx +1 -1
  200. package/src/components/theme/SearchWidget/SearchWidget.jsx +38 -98
  201. package/src/components/theme/Sitemap/Sitemap.jsx +5 -3
  202. package/src/components/theme/View/AlbumView.jsx +9 -1
  203. package/src/components/theme/View/DefaultView.jsx +1 -1
  204. package/src/components/theme/View/EventDatesInfo.jsx +2 -1
  205. package/src/components/theme/View/EventView.jsx +6 -2
  206. package/src/components/theme/View/FileView.jsx +23 -18
  207. package/src/components/theme/View/ImageView.jsx +37 -32
  208. package/src/components/theme/View/LinkView.jsx +53 -78
  209. package/src/components/theme/View/ListingView.jsx +33 -27
  210. package/src/components/theme/View/NewsItemView.jsx +10 -5
  211. package/src/components/theme/View/RenderBlocks.jsx +56 -21
  212. package/src/components/theme/View/RenderEmptyBlock.jsx +5 -0
  213. package/src/components/theme/View/SummaryView.jsx +47 -38
  214. package/src/components/theme/View/TabularView.jsx +59 -53
  215. package/src/components/theme/Widgets/DateWidget.jsx +2 -1
  216. package/src/components/theme/Widgets/DatetimeWidget.jsx +2 -1
  217. package/src/components/theme/Widgets/RelationsWidget.jsx +13 -11
  218. package/src/config/Blocks.jsx +44 -0
  219. package/src/config/ControlPanels.js +2 -0
  220. package/src/config/NonContentRoutes.jsx +1 -0
  221. package/src/config/RichTextEditor/Blocks.jsx +2 -2
  222. package/src/config/RichTextEditor/FromHTML.jsx +2 -2
  223. package/src/config/RichTextEditor/Styles.jsx +1 -1
  224. package/src/config/Widgets.jsx +2 -0
  225. package/src/config/index.js +24 -0
  226. package/src/config/server.js +2 -0
  227. package/src/constants/ActionTypes.js +4 -0
  228. package/src/constants/Indexes.js +3 -1
  229. package/src/constants/Languages.js +8 -4
  230. package/src/express-middleware/devproxy.js +1 -1
  231. package/src/express-middleware/files.js +3 -3
  232. package/src/express-middleware/images.js +4 -4
  233. package/src/express-middleware/ok.js +16 -0
  234. package/src/express-middleware/robotstxt.js +1 -1
  235. package/src/express-middleware/sitemap.js +37 -5
  236. package/src/express-middleware/static.js +3 -3
  237. package/src/helpers/Api/Api.js +1 -1
  238. package/src/helpers/Blocks/Blocks.js +48 -0
  239. package/src/helpers/Blocks/Blocks.test.js +79 -0
  240. package/src/helpers/Extensions/index.js +2 -1
  241. package/src/helpers/Extensions/withBlockSchemaEnhancer.js +15 -11
  242. package/src/helpers/Extensions/withBlockSchemaEnhancer.test.js +145 -0
  243. package/src/helpers/FormValidation/FormValidation.js +40 -2
  244. package/src/helpers/FormValidation/FormValidation.test.js +73 -0
  245. package/src/helpers/Html/Html.jsx +3 -1
  246. package/src/helpers/Html/Html.test.jsx +5 -0
  247. package/src/helpers/MessageLabels/MessageLabels.js +80 -0
  248. package/src/helpers/Robots/Robots.js +24 -6
  249. package/src/helpers/ScrollToTop/ScrollToTop.jsx +5 -3
  250. package/src/helpers/Sitemap/Sitemap.js +44 -2
  251. package/src/helpers/Url/Url.js +27 -6
  252. package/src/helpers/Url/Url.test.js +26 -0
  253. package/src/helpers/Utils/UseDetectClickOutside.stories.jsx +191 -0
  254. package/src/helpers/Utils/Utils.js +63 -13
  255. package/src/helpers/Utils/Utils.test.js +4 -4
  256. package/src/helpers/Utils/usePagination.js +67 -14
  257. package/src/helpers/Utils/usePagination.test.js +115 -0
  258. package/src/helpers/index.js +20 -10
  259. package/src/hooks/client/useClient.js +11 -0
  260. package/src/hooks/clipboard/useClipboard.js +26 -0
  261. package/src/hooks/index.js +2 -0
  262. package/src/icons/grid-block.svg +11 -0
  263. package/src/middleware/Api.test.js +54 -0
  264. package/src/middleware/api.js +24 -6
  265. package/src/middleware/index.js +2 -2
  266. package/src/reducers/actions/actions.js +8 -6
  267. package/src/reducers/actions/actions.test.js +70 -0
  268. package/src/reducers/breadcrumbs/breadcrumbs.js +1 -1
  269. package/src/reducers/index.js +2 -0
  270. package/src/reducers/navigation/navigation.js +1 -1
  271. package/src/reducers/relations/relations.js +173 -0
  272. package/src/reducers/types/types.js +1 -1
  273. package/src/routes.js +14 -0
  274. package/src/server.jsx +28 -23
  275. package/src/start-server.js +2 -2
  276. package/test-setup-config.js +2 -0
  277. package/theme/themes/pastanaga/extras/blocks.less +3 -1
  278. package/theme/themes/pastanaga/extras/contents.less +1 -0
  279. package/theme/themes/pastanaga/extras/grid.less +426 -0
  280. package/theme/themes/pastanaga/extras/main.less +3 -1
  281. package/theme/themes/pastanaga/extras/search.less +6 -0
  282. package/theme/themes/pastanaga/extras/sidebar.less +4 -0
  283. package/theme/themes/pastanaga/extras/toc.less +29 -0
  284. package/theme/themes/pastanaga/extras/userscontrolpanel.less +99 -76
  285. package/.changelog.draft +0 -31
  286. package/.editorconfig +0 -36
  287. package/.storybook/main.js +0 -127
  288. package/.storybook/manager.js +0 -15
  289. package/.storybook/preview.js +0 -21
  290. package/.storybook/static/previewImage.svg +0 -48
  291. package/.yarnrc.yml +0 -5
  292. package/jsdoc.json +0 -16
  293. package/netlify.toml +0 -5
  294. package/pyvenv.cfg +0 -3
  295. package/share/man/man1/ttx.1 +0 -225
  296. package/src/components/theme/Header/Header.md +0 -27
  297. package/towncrier.toml +0 -33
@@ -0,0 +1,531 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { capitalize, find } from 'lodash';
3
+ import { compose } from 'redux';
4
+ import { useSelector, useDispatch } from 'react-redux';
5
+ import { FormattedMessage, useIntl } from 'react-intl';
6
+ import { toast } from 'react-toastify';
7
+ import {
8
+ Button,
9
+ Divider,
10
+ Dropdown,
11
+ Form,
12
+ Header,
13
+ Input,
14
+ Popup,
15
+ Tab,
16
+ } from 'semantic-ui-react';
17
+ import withObjectBrowser from '@plone/volto/components/manage/Sidebar/ObjectBrowser';
18
+ import { messages } from '@plone/volto/helpers';
19
+ import { Icon, Toast } from '@plone/volto/components';
20
+ import { rebuildRelations, queryRelations } from '@plone/volto/actions';
21
+ import RelationsListing from './RelationsListing';
22
+ import BrokenRelations from './BrokenRelations';
23
+ import helpSVG from '@plone/volto/icons/help.svg';
24
+ import clearSVG from '@plone/volto/icons/clear.svg';
25
+ import navTreeSVG from '@plone/volto/icons/nav.svg';
26
+
27
+ const RelationsMatrix = (props) => {
28
+ const intl = useIntl();
29
+ const dispatch = useDispatch();
30
+
31
+ const [query_source, setQuery_source] = useState('');
32
+ const [query_target, setQuery_target] = useState('');
33
+ const [potential_targets_path, setPotential_targets_path] = useState('');
34
+ const [potential_sources_path, setPotential_sources_path] = useState('');
35
+ const [relationtype, setRelationtype] = useState(undefined);
36
+
37
+ const actions = useSelector((state) => state.actions?.actions ?? {});
38
+ const can_fix_relations = find(actions.user, {
39
+ id: 'plone_setup',
40
+ });
41
+
42
+ const relationtypes = useSelector((state) => state.relations?.stats?.stats);
43
+ const relationsListError = useSelector(
44
+ (state) => state.relations?.list?.error?.response?.body?.error,
45
+ );
46
+ const brokenRelations = useSelector(
47
+ (state) => state.relations?.stats?.broken,
48
+ );
49
+
50
+ let filter_options = useSelector((state) => state.groups.filter_groups);
51
+ if (filter_options) {
52
+ filter_options = filter_options.map((group) => ({
53
+ value: group.id,
54
+ label: group.title || group.id,
55
+ }));
56
+ filter_options.sort(function (a, b) {
57
+ var labelA = a.label.toUpperCase();
58
+ var labelB = b.label.toUpperCase();
59
+ if (labelA < labelB) {
60
+ return -1;
61
+ }
62
+ if (labelA > labelB) {
63
+ return 1;
64
+ }
65
+ return 0;
66
+ });
67
+ }
68
+
69
+ useEffect(() => {
70
+ dispatch(queryRelations());
71
+ }, [dispatch]);
72
+
73
+ const onReset = (event) => {
74
+ let element = event.target.querySelector('input');
75
+ element.value = '';
76
+ element.focus();
77
+ let searchtype = element.name;
78
+ switch (searchtype) {
79
+ case 'SearchY':
80
+ setQuery_source('');
81
+ break;
82
+ case 'SearchX':
83
+ setQuery_target('');
84
+ break;
85
+ case 'showPotentialTargets':
86
+ setPotential_targets_path('/');
87
+ break;
88
+ case 'showPotentialSources':
89
+ setPotential_sources_path('/');
90
+ break;
91
+ default:
92
+ break;
93
+ }
94
+ };
95
+
96
+ // search for sources
97
+ const onChangeSearchYs = (event) => {
98
+ if (event.target.value.length > 1) {
99
+ setQuery_source(event.target.value);
100
+ } else {
101
+ setQuery_source('');
102
+ }
103
+ };
104
+
105
+ // search for targets
106
+ const onChangeSearchXs = (event) => {
107
+ if (event.target.value.length > 1) {
108
+ setQuery_target(event.target.value);
109
+ } else {
110
+ setQuery_source('');
111
+ }
112
+ };
113
+
114
+ const onChangeRelation = (event, { value }) => {
115
+ setRelationtype(value);
116
+ };
117
+
118
+ const onChangeShowPotentialSources = (_value) => {
119
+ let newValue = _value;
120
+ setPotential_sources_path(newValue);
121
+ };
122
+
123
+ const onChangeShowPotentialTargets = (_value) => {
124
+ let newValue = _value;
125
+ setPotential_targets_path(newValue);
126
+ };
127
+
128
+ const rebuildRelationsHandler = (flush = false) => {
129
+ dispatch(rebuildRelations(flush))
130
+ .then(() => {
131
+ dispatch(queryRelations());
132
+ })
133
+ .then(() => {
134
+ dispatch(queryRelations(null, true, 'broken'));
135
+ })
136
+ .then(() => {
137
+ toast.success(
138
+ <Toast
139
+ success
140
+ title={intl.formatMessage(messages.success)}
141
+ content="Relations updated"
142
+ />,
143
+ );
144
+ })
145
+ .catch((error) => {
146
+ // TODO: The true error sent by the API is shadowed by the superagent one
147
+ // Update this when this issue is fixed.
148
+ const shadowedError = JSON.parse(error.response.text);
149
+ toast.error(
150
+ <Toast
151
+ error
152
+ title={shadowedError.error.type}
153
+ content={shadowedError.error.message}
154
+ />,
155
+ );
156
+ });
157
+ };
158
+
159
+ const clear_potential_sources_path = () => {
160
+ setPotential_sources_path('');
161
+ // onChange(id, undefined);
162
+ };
163
+
164
+ const clear_potential_targets_path = () => {
165
+ setPotential_targets_path('');
166
+ // onChange(id, undefined);
167
+ };
168
+
169
+ const panes = [
170
+ {
171
+ menuItem: intl.formatMessage(messages.inspectRelations),
172
+ pane: (
173
+ <Tab.Pane attached={true} key="fix">
174
+ {relationtypes ? (
175
+ <div className="controlpanel_matrix">
176
+ <div className="controlpanel_select_relation">
177
+ <Divider hidden />
178
+ <Form className="select_relation">
179
+ <Form.Field>
180
+ <Header as="h3">
181
+ <Header.Content>
182
+ <FormattedMessage
183
+ id="Relation name"
184
+ defaultMessage="Relation"
185
+ />{' '}
186
+ <Dropdown
187
+ placeholder={
188
+ relationtype ||
189
+ intl.formatMessage(messages.selectRelation)
190
+ }
191
+ >
192
+ <Dropdown.Menu>
193
+ {Object.keys(relationtypes).map((relationtype) => (
194
+ <Dropdown.Item
195
+ onClick={onChangeRelation}
196
+ value={relationtype}
197
+ className={`select-relation-${relationtype}`}
198
+ key={relationtype}
199
+ >
200
+ {`${relationtype} (${relationtypes[relationtype]})`}
201
+ </Dropdown.Item>
202
+ ))}
203
+ </Dropdown.Menu>
204
+ </Dropdown>
205
+ </Header.Content>
206
+ </Header>
207
+ </Form.Field>
208
+ </Form>
209
+ </div>
210
+ {relationtype ? (
211
+ <>
212
+ <div className="controlpanel_search_wrapper">
213
+ <div className="controlpanel_search_y">
214
+ <Header as="h4">
215
+ <Header.Content>
216
+ <FormattedMessage
217
+ id="Source"
218
+ defaultMessage="Source"
219
+ />
220
+ </Header.Content>
221
+ </Header>
222
+ <Form className="search_y" onSubmit={onReset}>
223
+ <Form.Field>
224
+ <Input
225
+ name="SearchY"
226
+ placeholder={intl.formatMessage(
227
+ messages.searchRelationSource,
228
+ )}
229
+ onChange={onChangeSearchYs}
230
+ id="y-search-input"
231
+ />
232
+ <Button.Group>
233
+ <Button
234
+ basic
235
+ className="cancel"
236
+ aria-label="cancel"
237
+ onClick={(e) => {
238
+ e.preventDefault();
239
+ e.stopPropagation();
240
+ document.querySelector(
241
+ 'input[name="SearchY"]',
242
+ ).value = '';
243
+ setQuery_source('');
244
+ }}
245
+ >
246
+ <Icon name={clearSVG} size="24px" />
247
+ </Button>
248
+ </Button.Group>
249
+ </Form.Field>
250
+ </Form>
251
+ <Form
252
+ className="add_potential_sources"
253
+ onSubmit={onReset}
254
+ >
255
+ <Form.Field>
256
+ <Input
257
+ name="showPotentialSources"
258
+ type="url"
259
+ value={potential_sources_path}
260
+ placeholder={intl.formatMessage(
261
+ messages.addPotentialSourcesPath,
262
+ )}
263
+ onChange={({ target }) =>
264
+ onChangeShowPotentialSources(target.value)
265
+ }
266
+ id="potential-sources-path-input"
267
+ />
268
+ {potential_sources_path?.length > 0 ? (
269
+ <Button.Group>
270
+ <Button
271
+ basic
272
+ className="cancel"
273
+ aria-label="clearUrlBrowser"
274
+ onClick={(e) => {
275
+ e.preventDefault();
276
+ e.stopPropagation();
277
+ clear_potential_sources_path();
278
+ }}
279
+ >
280
+ <Icon name={clearSVG} size="24px" />
281
+ </Button>
282
+ </Button.Group>
283
+ ) : (
284
+ <Button.Group>
285
+ <Button
286
+ basic
287
+ icon
288
+ aria-label="openUrlBrowser"
289
+ onClick={(e) => {
290
+ e.preventDefault();
291
+ e.stopPropagation();
292
+ props.openObjectBrowser({
293
+ mode: 'link',
294
+ overlay: true,
295
+ onSelectItem: (url) => {
296
+ onChangeShowPotentialSources(url);
297
+ },
298
+ });
299
+ }}
300
+ >
301
+ <Icon name={navTreeSVG} size="24px" />
302
+ </Button>
303
+ </Button.Group>
304
+ )}
305
+ </Form.Field>
306
+ <FormattedMessage
307
+ id="Show potential sources. Not only objects that are source of some relation."
308
+ defaultMessage="Show potential sources. Not only objects that are source of some relation."
309
+ />
310
+ </Form>
311
+ </div>
312
+ <div className="controlpanel_search_x">
313
+ <Form className="search_x" onSubmit={onReset}>
314
+ <Header as="h4">
315
+ <Header.Content>
316
+ <FormattedMessage
317
+ id="Target"
318
+ defaultMessage="Target"
319
+ />
320
+ </Header.Content>
321
+ </Header>
322
+ <Form.Field>
323
+ <Input
324
+ name="SearchX"
325
+ placeholder={intl.formatMessage(
326
+ messages.searchRelationTarget,
327
+ )}
328
+ onChange={onChangeSearchXs}
329
+ id="x-search-input"
330
+ />
331
+ <Button.Group>
332
+ <Button
333
+ basic
334
+ className="cancel"
335
+ aria-label="cancel"
336
+ onClick={(e) => {
337
+ e.preventDefault();
338
+ e.stopPropagation();
339
+ document.querySelector(
340
+ 'input[name="SearchX"]',
341
+ ).value = '';
342
+ setQuery_target('');
343
+ }}
344
+ >
345
+ <Icon name={clearSVG} size="24px" />
346
+ </Button>
347
+ </Button.Group>
348
+ </Form.Field>
349
+ </Form>
350
+ <Form
351
+ className="add_potential_targets"
352
+ onSubmit={onReset}
353
+ >
354
+ <Form.Field>
355
+ <Input
356
+ name="showPotentialTargets"
357
+ type="url"
358
+ value={potential_targets_path}
359
+ placeholder={intl.formatMessage(
360
+ messages.addPotentialTargetsPath,
361
+ )}
362
+ onChange={({ target }) =>
363
+ onChangeShowPotentialTargets(target.value)
364
+ }
365
+ id="potential-targets-path-input"
366
+ />
367
+ {potential_targets_path?.length > 0 ? (
368
+ <Button.Group>
369
+ <Button
370
+ basic
371
+ className="cancel"
372
+ aria-label="clearUrlBrowser"
373
+ onClick={(e) => {
374
+ e.preventDefault();
375
+ e.stopPropagation();
376
+ clear_potential_targets_path();
377
+ }}
378
+ >
379
+ <Icon name={clearSVG} size="24px" />
380
+ </Button>
381
+ </Button.Group>
382
+ ) : (
383
+ <Button.Group>
384
+ <Button
385
+ basic
386
+ icon
387
+ aria-label="openUrlBrowser"
388
+ onClick={(e) => {
389
+ e.preventDefault();
390
+ e.stopPropagation();
391
+ props.openObjectBrowser({
392
+ mode: 'link',
393
+ overlay: true,
394
+ onSelectItem: (url) => {
395
+ onChangeShowPotentialTargets(url);
396
+ },
397
+ });
398
+ }}
399
+ >
400
+ <Icon name={navTreeSVG} size="24px" />
401
+ </Button>
402
+ </Button.Group>
403
+ )}
404
+ </Form.Field>
405
+ <div className="foo">
406
+ <FormattedMessage
407
+ id="Show potential targets. Not only objects that are target of some relation."
408
+ defaultMessage="Show potential targets. Not only objects that are target of some relation."
409
+ />{' '}
410
+ <Popup
411
+ trigger={
412
+ <a
413
+ href="https://6.docs.plone.org/volto/recipes/widget.html#restricting-potential-targets"
414
+ target="_blank"
415
+ rel="noopener noreferrer"
416
+ >
417
+ <Icon name={helpSVG} size="16px" />
418
+ </a>
419
+ }
420
+ >
421
+ <Popup.Header>Respect constraints</Popup.Header>
422
+ <Popup.Content>
423
+ <div>
424
+ See docs.plone.org on how to respect
425
+ constraints.
426
+ </div>
427
+ </Popup.Content>
428
+ </Popup>
429
+ </div>
430
+ </Form>
431
+ </div>
432
+ </div>
433
+ <div className="controlpanel_listing_wrapper">
434
+ <RelationsListing
435
+ relationtype={relationtype}
436
+ query_source={query_source}
437
+ query_target={query_target}
438
+ potential_targets_path={potential_targets_path}
439
+ potential_sources_path={potential_sources_path}
440
+ />
441
+ </div>
442
+ </>
443
+ ) : null}
444
+ </div>
445
+ ) : (
446
+ <p>{relationsListError?.message}</p>
447
+ )}
448
+ </Tab.Pane>
449
+ ),
450
+ },
451
+ {
452
+ menuItem: intl.formatMessage(messages.fixRelations),
453
+ pane: (
454
+ <Tab.Pane attached={true} key="rebuild">
455
+ {brokenRelations && Object.keys(brokenRelations).length > 0 ? (
456
+ <div>
457
+ {can_fix_relations ? (
458
+ <React.Fragment>
459
+ <Divider hidden />
460
+ <h2>
461
+ {capitalize(intl.formatMessage(messages.rebuildRelations))}
462
+ </h2>
463
+
464
+ <Button.Group>
465
+ <Button
466
+ primary
467
+ onClick={() => rebuildRelationsHandler(false)}
468
+ content={intl.formatMessage(messages.rebuildRelations)}
469
+ aria-label={intl.formatMessage(messages.rebuildRelations)}
470
+ />
471
+ </Button.Group>
472
+
473
+ <Divider hidden />
474
+ <h2>
475
+ {capitalize(
476
+ intl.formatMessage(messages.flushAndRebuildRelations),
477
+ )}
478
+ </h2>
479
+ <ul>
480
+ <li>
481
+ Regenerate intIds (tokens of relations in relation
482
+ catalog)
483
+ </li>
484
+ <li>Rebuild relations</li>
485
+ </ul>
486
+ <p>Check the log for details!</p>
487
+ <p>
488
+ <b>Warning</b>: If you have add-ons relying on intIds, you
489
+ should not flush them.
490
+ </p>
491
+ <Divider hidden />
492
+ <Button.Group>
493
+ <Button
494
+ secondary
495
+ color="red"
496
+ onClick={() => rebuildRelationsHandler(true)}
497
+ content={intl.formatMessage(
498
+ messages.flushAndRebuildRelations,
499
+ )}
500
+ aria-label={intl.formatMessage(
501
+ messages.flushAndRebuildRelations,
502
+ )}
503
+ />
504
+ </Button.Group>
505
+ </React.Fragment>
506
+ ) : null}
507
+ <BrokenRelations />
508
+ </div>
509
+ ) : (
510
+ <div>
511
+ <FormattedMessage
512
+ id="No broken relations found."
513
+ defaultMessage="No broken relations found."
514
+ />
515
+ </div>
516
+ )}
517
+ </Tab.Pane>
518
+ ),
519
+ },
520
+ ];
521
+
522
+ return (
523
+ <Tab
524
+ panes={panes}
525
+ renderActiveOnly={false}
526
+ menu={{ secondary: true, pointing: true, attached: true, tabular: true }}
527
+ />
528
+ );
529
+ };
530
+
531
+ export default compose(withObjectBrowser)(RelationsMatrix);
@@ -9,7 +9,7 @@ import { useHistory } from 'react-router';
9
9
  import { Link, useLocation } from 'react-router-dom';
10
10
  import { FormattedMessage, useIntl } from 'react-intl';
11
11
  import { useDispatch, useSelector } from 'react-redux';
12
- import { Container, Segment } from 'semantic-ui-react';
12
+ import { Segment } from 'semantic-ui-react';
13
13
  import { Helmet, messages } from '@plone/volto/helpers';
14
14
  import {
15
15
  getControlpanel,
@@ -63,7 +63,7 @@ const UserGroupMembershipPanel = () => {
63
63
 
64
64
  return (
65
65
  <>
66
- <Container className="users-control-panel">
66
+ <div className="users-control-panel">
67
67
  <Helmet title={intl.formatMessage(messages.usergroupmemberbership)} />
68
68
  <Segment.Group raised>
69
69
  <Segment className="primary">
@@ -106,7 +106,7 @@ const UserGroupMembershipPanel = () => {
106
106
  </Segment>
107
107
  )}
108
108
  </Segment.Group>
109
- </Container>
109
+ </div>
110
110
 
111
111
  {__CLIENT__ && (
112
112
  <Portal node={document.getElementById('toolbar')}>