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

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 (318) hide show
  1. package/.yarn/install-state.gz +0 -0
  2. package/CHANGELOG.md +549 -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 +58 -5
  8. package/cypress/support/e2e.js +1 -2
  9. package/cypress/support/volto-slate.js +4 -5
  10. package/docker-compose.yml +1 -1
  11. package/locales/ca/LC_MESSAGES/volto.po +282 -7
  12. package/locales/ca.json +1 -1
  13. package/locales/de/LC_MESSAGES/volto.po +301 -26
  14. package/locales/de.json +1 -1
  15. package/locales/en/LC_MESSAGES/volto.po +281 -6
  16. package/locales/en.json +1 -1
  17. package/locales/es/LC_MESSAGES/volto.po +291 -16
  18. package/locales/es.json +1 -1
  19. package/locales/eu/LC_MESSAGES/volto.po +282 -7
  20. package/locales/eu.json +1 -1
  21. package/locales/fi/LC_MESSAGES/volto.po +4891 -0
  22. package/locales/fi.json +1 -1
  23. package/locales/fr/LC_MESSAGES/volto.po +282 -7
  24. package/locales/fr.json +1 -1
  25. package/locales/it/LC_MESSAGES/volto.po +284 -9
  26. package/locales/it.json +1 -1
  27. package/locales/ja/LC_MESSAGES/volto.po +282 -7
  28. package/locales/ja.json +1 -1
  29. package/locales/nl/LC_MESSAGES/volto.po +937 -650
  30. package/locales/nl.json +1 -1
  31. package/locales/pt/LC_MESSAGES/volto.po +282 -7
  32. package/locales/pt.json +1 -1
  33. package/locales/pt_BR/LC_MESSAGES/volto.po +291 -16
  34. package/locales/pt_BR.json +1 -1
  35. package/locales/ro/LC_MESSAGES/volto.po +282 -7
  36. package/locales/ro.json +1 -1
  37. package/locales/volto.pot +282 -7
  38. package/locales/zh_CN/LC_MESSAGES/volto.po +282 -7
  39. package/locales/zh_CN.json +1 -1
  40. package/package.json +8 -6
  41. package/packages/volto-slate/build/messages/src/blocks/Table/TableBlockEdit.json +1 -1
  42. package/packages/volto-slate/build/messages/src/blocks/Text/DefaultTextBlockEditor.json +1 -1
  43. package/packages/volto-slate/build/messages/src/blocks/Text/DetachedTextBlockEditor.json +1 -1
  44. package/packages/volto-slate/build/messages/src/blocks/Text/SlashMenu.json +1 -1
  45. package/packages/volto-slate/build/messages/src/editor/plugins/AdvancedLink/index.json +1 -1
  46. package/packages/volto-slate/build/messages/src/editor/plugins/Link/index.json +1 -1
  47. package/packages/volto-slate/build/messages/src/editor/plugins/Table/index.json +1 -1
  48. package/packages/volto-slate/build/messages/src/elementEditor/messages.json +1 -1
  49. package/packages/volto-slate/build/messages/src/widgets/HtmlSlateWidget.json +1 -1
  50. package/packages/volto-slate/build/messages/src/widgets/RichTextWidgetView.json +1 -1
  51. package/packages/volto-slate/package.json +1 -1
  52. package/packages/volto-slate/src/actions/index.js +1 -1
  53. package/packages/volto-slate/src/blocks/Table/TableBlockEdit.jsx +21 -212
  54. package/packages/volto-slate/src/blocks/Table/schema.js +122 -0
  55. package/packages/volto-slate/src/blocks/Text/DefaultTextBlockEditor.jsx +8 -3
  56. package/packages/volto-slate/src/blocks/Text/SlashMenu.jsx +4 -3
  57. package/packages/volto-slate/src/blocks/Text/TextBlockView.jsx +20 -16
  58. package/packages/volto-slate/src/blocks/Text/extensions/withDeserializers.js +3 -1
  59. package/packages/volto-slate/src/blocks/Text/index.js +10 -2
  60. package/packages/volto-slate/src/editor/config.jsx +5 -4
  61. package/packages/volto-slate/src/editor/deserialize.js +0 -1
  62. package/packages/volto-slate/src/editor/index.js +4 -4
  63. package/packages/volto-slate/src/editor/less/slate.less +28 -0
  64. package/packages/volto-slate/src/editor/plugins/StyleMenu/StyleMenu.jsx +14 -4
  65. package/packages/volto-slate/src/editor/plugins/StyleMenu/utils.js +14 -5
  66. package/packages/volto-slate/src/editor/render.jsx +68 -8
  67. package/packages/volto-slate/src/editor/ui/SlateContextToolbar.jsx +2 -2
  68. package/packages/volto-slate/src/editor/ui/index.js +15 -15
  69. package/packages/volto-slate/src/index.js +2 -2
  70. package/packages/volto-slate/src/utils/blocks.js +7 -0
  71. package/packages/volto-slate/src/widgets/RichTextWidget.jsx +15 -8
  72. package/razzle.config.js +28 -0
  73. package/src/actions/index.js +6 -0
  74. package/src/actions/language/language.js +9 -8
  75. package/src/actions/querystringsearch/querystringsearch.js +20 -14
  76. package/src/actions/relations/rebuild.js +25 -0
  77. package/src/actions/relations/relations.js +86 -0
  78. package/src/actions/relations/relations.test.js +15 -0
  79. package/src/components/index.js +3 -0
  80. package/src/components/manage/Add/Add.jsx +2 -2
  81. package/src/components/manage/AnchorPlugin/index.jsx +2 -2
  82. package/src/components/manage/AnchorPlugin/utils/EditorUtils.js +3 -1
  83. package/src/components/manage/BlockChooser/BlockChooser.jsx +14 -5
  84. package/src/components/manage/BlockChooser/BlockChooser.test.jsx +5 -0
  85. package/src/components/manage/Blocks/Block/BlocksForm.jsx +19 -2
  86. package/src/components/manage/Blocks/Block/Edit.jsx +1 -1
  87. package/src/components/manage/Blocks/Block/Style.jsx +2 -2
  88. package/src/components/manage/Blocks/Container/Data.jsx +32 -0
  89. package/src/components/manage/Blocks/Container/Edit.jsx +174 -0
  90. package/src/components/manage/Blocks/Container/EditBlockWrapper.jsx +120 -0
  91. package/src/components/manage/Blocks/Container/NewBlockAddButton.jsx +84 -0
  92. package/src/components/manage/Blocks/Container/SimpleContainerToolbar.jsx +54 -0
  93. package/src/components/manage/Blocks/Grid/Edit.jsx +33 -0
  94. package/src/components/manage/Blocks/Grid/View.jsx +43 -0
  95. package/src/components/manage/Blocks/Grid/adapter.js +14 -0
  96. package/src/components/manage/Blocks/Grid/grid-1.svg +6 -0
  97. package/src/components/manage/Blocks/Grid/grid-2.svg +9 -0
  98. package/src/components/manage/Blocks/Grid/grid-3.svg +10 -0
  99. package/src/components/manage/Blocks/Grid/grid-4.svg +11 -0
  100. package/src/components/manage/Blocks/Grid/schema.js +35 -0
  101. package/src/components/manage/Blocks/Grid/templates.js +47 -0
  102. package/src/components/manage/Blocks/HeroImageLeft/Edit.jsx +6 -1
  103. package/src/components/manage/Blocks/Image/Edit.jsx +51 -12
  104. package/src/components/manage/Blocks/Image/Edit.test.jsx +2 -0
  105. package/src/components/manage/Blocks/Image/ImageSidebar.jsx +66 -16
  106. package/src/components/manage/Blocks/Image/View.jsx +25 -5
  107. package/src/components/manage/Blocks/Image/View.test.jsx +20 -0
  108. package/src/components/manage/Blocks/Image/schema.js +12 -9
  109. package/src/components/manage/Blocks/Image/utils.js +14 -0
  110. package/src/components/manage/Blocks/LeadImage/Edit.jsx +32 -10
  111. package/src/components/manage/Blocks/LeadImage/Edit.test.jsx +11 -1
  112. package/src/components/manage/Blocks/LeadImage/LeadImageSidebar.jsx +28 -9
  113. package/src/components/manage/Blocks/LeadImage/LeadImageSidebar.test.jsx +8 -2
  114. package/src/components/manage/Blocks/LeadImage/View.jsx +50 -38
  115. package/src/components/manage/Blocks/LeadImage/View.test.jsx +11 -1
  116. package/src/components/manage/Blocks/Listing/DefaultTemplate.jsx +18 -3
  117. package/src/components/manage/Blocks/Listing/Edit.jsx +0 -14
  118. package/src/components/manage/Blocks/Listing/ListingBody.jsx +30 -8
  119. package/src/components/manage/Blocks/Listing/ListingBody.test.jsx +20 -0
  120. package/src/components/manage/Blocks/Listing/SummaryTemplate.jsx +1 -1
  121. package/src/components/manage/Blocks/Listing/getAsyncData.js +9 -3
  122. package/src/components/manage/Blocks/Listing/withQuerystringResults.jsx +26 -18
  123. package/src/components/manage/Blocks/Search/SearchBlockEdit.jsx +5 -4
  124. package/src/components/manage/Blocks/Search/SearchBlockView.jsx +2 -1
  125. package/src/components/manage/Blocks/Search/components/DateRangeFacet.jsx +4 -1
  126. package/src/components/manage/Blocks/Search/components/Facets.jsx +64 -4
  127. package/src/components/manage/Blocks/Search/components/SearchInput.jsx +9 -2
  128. package/src/components/manage/Blocks/Search/components/index.js +13 -13
  129. package/src/components/manage/Blocks/Search/hocs/index.js +2 -2
  130. package/src/components/manage/Blocks/Search/hocs/withQueryString.jsx +2 -2
  131. package/src/components/manage/Blocks/Search/hocs/withSearch.jsx +43 -15
  132. package/src/components/manage/Blocks/Search/layout/LeftColumnFacets.jsx +17 -5
  133. package/src/components/manage/Blocks/Search/layout/RightColumnFacets.jsx +17 -5
  134. package/src/components/manage/Blocks/Search/layout/TopSideFacets.jsx +21 -5
  135. package/src/components/manage/Blocks/Search/schema.js +16 -1
  136. package/src/components/manage/Blocks/Teaser/Body.jsx +0 -1
  137. package/src/components/manage/Blocks/Teaser/DefaultBody.jsx +5 -10
  138. package/src/components/manage/Blocks/Teaser/schema.js +5 -0
  139. package/src/components/manage/Blocks/Title/View.jsx +15 -5
  140. package/src/components/manage/Blocks/Title/View.test.jsx +16 -1
  141. package/src/components/manage/Blocks/ToC/Schema.jsx +5 -1
  142. package/src/components/manage/Blocks/ToC/View.jsx +8 -1
  143. package/src/components/manage/Blocks/ToC/variations/DefaultTocRenderer.jsx +17 -4
  144. package/src/components/manage/Blocks/ToC/variations/HorizontalMenu.jsx +148 -10
  145. package/src/components/manage/Blocks/ToC/variations/index.js +3 -1
  146. package/src/components/manage/Contents/Contents.jsx +47 -32
  147. package/src/components/manage/Contents/ContentsItem.jsx +6 -0
  148. package/src/components/manage/Contents/ContentsUploadModal.jsx +10 -5
  149. package/src/components/manage/Controlpanels/AddonsControlpanel.jsx +3 -3
  150. package/src/components/manage/Controlpanels/Controlpanels.jsx +199 -224
  151. package/src/components/manage/Controlpanels/Controlpanels.test.jsx +46 -7
  152. package/src/components/manage/Controlpanels/Relations/BrokenRelations.jsx +66 -0
  153. package/src/components/manage/Controlpanels/Relations/Relations.jsx +114 -0
  154. package/src/components/manage/Controlpanels/Relations/RelationsListing.jsx +479 -0
  155. package/src/components/manage/Controlpanels/Relations/RelationsMatrix.jsx +531 -0
  156. package/src/components/manage/Controlpanels/Users/UserGroupMembershipControlPanel.jsx +3 -3
  157. package/src/components/manage/Controlpanels/Users/UserGroupMembershipListing.jsx +51 -82
  158. package/src/components/manage/Controlpanels/Users/UserGroupMembershipMatrix.jsx +79 -75
  159. package/src/components/manage/DragDropList/DragDropList.jsx +18 -13
  160. package/src/components/manage/Form/Form.jsx +5 -3
  161. package/src/components/manage/Form/InlineForm.jsx +39 -9
  162. package/src/components/manage/Form/InlineFormState.js +8 -0
  163. package/src/components/manage/History/History.jsx +11 -1
  164. package/src/components/manage/LinksToItem/LinksToItem.jsx +209 -0
  165. package/src/components/manage/LinksToItem/LinksToItem.test.jsx +97 -0
  166. package/src/components/manage/Multilingual/CreateTranslation.jsx +2 -2
  167. package/src/components/manage/Multilingual/TranslationObject.jsx +4 -3
  168. package/src/components/manage/Preferences/ChangePassword.jsx +2 -2
  169. package/src/components/manage/Preferences/PersonalPreferences.jsx +2 -2
  170. package/src/components/manage/Sharing/Sharing.jsx +5 -1
  171. package/src/components/manage/Sidebar/AlignBlock.jsx +1 -1
  172. package/src/components/manage/TemplateChooser/TemplateChooser.jsx +38 -0
  173. package/src/components/manage/TemplateChooser/TemplateChooser.test.jsx +34 -0
  174. package/src/components/manage/TemplateChooser/template.svg +10 -0
  175. package/src/components/manage/Toast/Toast.jsx +2 -2
  176. package/src/components/manage/Toolbar/More.jsx +15 -0
  177. package/src/components/manage/Toolbar/Types.jsx +2 -2
  178. package/src/components/manage/UniversalLink/UniversalLink.jsx +2 -6
  179. package/src/components/manage/UniversalLink/UniversalLink.test.jsx +36 -0
  180. package/src/components/manage/Widgets/ColorPickerWidget.jsx +6 -1
  181. package/src/components/manage/Widgets/DatetimeWidget.jsx +9 -5
  182. package/src/components/manage/Widgets/FileWidget.jsx +2 -1
  183. package/src/components/manage/Widgets/ObjectListWidget.jsx +3 -8
  184. package/src/components/manage/Widgets/RecurrenceWidget/ByDayField.jsx +2 -1
  185. package/src/components/manage/Widgets/RecurrenceWidget/MonthOfTheYearField.jsx +2 -1
  186. package/src/components/manage/Widgets/RecurrenceWidget/Occurences.jsx +2 -1
  187. package/src/components/manage/Widgets/RecurrenceWidget/RecurrenceWidget.jsx +8 -3
  188. package/src/components/manage/Widgets/RecurrenceWidget/WeekdayOfTheMonthField.jsx +2 -1
  189. package/src/components/manage/Widgets/SelectUtils.js +1 -1
  190. package/src/components/manage/Widgets/SelectWidget.jsx +1 -1
  191. package/src/components/theme/Anontools/Anontools.jsx +44 -72
  192. package/src/components/theme/Anontools/Anontools.stories.jsx +16 -6
  193. package/src/components/theme/Anontools/Anontools.test.jsx +16 -2
  194. package/src/components/theme/Breadcrumbs/Breadcrumbs.jsx +52 -99
  195. package/src/components/theme/Breadcrumbs/Breadcrumbs.stories.jsx +14 -13
  196. package/src/components/theme/Comments/CommentEditModal.jsx +63 -115
  197. package/src/components/theme/Component/Component.jsx +1 -1
  198. package/src/components/theme/ContactForm/ContactForm.jsx +108 -192
  199. package/src/components/theme/ContactForm/ContactForm.stories.jsx +1 -1
  200. package/src/components/theme/ContactForm/ContactForm.test.jsx +2 -3
  201. package/src/components/theme/Footer/Footer.jsx +2 -13
  202. package/src/components/theme/Header/Header.jsx +37 -63
  203. package/src/components/theme/Header/Header.test.jsx +18 -0
  204. package/src/components/theme/Icon/Icon.jsx +2 -2
  205. package/src/components/theme/Image/Image.jsx +96 -0
  206. package/src/components/theme/Image/Image.test.jsx +125 -0
  207. package/src/components/theme/LanguageSelector/LanguageSelector.js +8 -3
  208. package/src/components/theme/Login/Login.jsx +1 -0
  209. package/src/components/theme/Logo/Logo.jsx +4 -1
  210. package/src/components/theme/MultilingualRedirector/MultilingualRedirector.jsx +2 -2
  211. package/src/components/theme/Navigation/NavItem.jsx +4 -2
  212. package/src/components/theme/NotFound/NotFound.jsx +55 -41
  213. package/src/components/theme/PasswordReset/PasswordReset.jsx +7 -4
  214. package/src/components/theme/PasswordReset/RequestPasswordReset.jsx +1 -1
  215. package/src/components/theme/PreviewImage/PreviewImage.jsx +25 -14
  216. package/src/components/theme/PreviewImage/PreviewImage.test.js +39 -16
  217. package/src/components/theme/SearchWidget/SearchWidget.jsx +38 -98
  218. package/src/components/theme/Sitemap/Sitemap.jsx +5 -3
  219. package/src/components/theme/View/AlbumView.jsx +20 -16
  220. package/src/components/theme/View/DefaultView.jsx +1 -1
  221. package/src/components/theme/View/EventDatesInfo.jsx +2 -1
  222. package/src/components/theme/View/EventView.jsx +36 -25
  223. package/src/components/theme/View/FileView.jsx +23 -18
  224. package/src/components/theme/View/ImageView.jsx +40 -32
  225. package/src/components/theme/View/ImageView.test.jsx +4 -0
  226. package/src/components/theme/View/LinkView.jsx +53 -78
  227. package/src/components/theme/View/ListingView.jsx +36 -28
  228. package/src/components/theme/View/NewsItemView.jsx +16 -17
  229. package/src/components/theme/View/RenderBlocks.jsx +56 -21
  230. package/src/components/theme/View/RenderEmptyBlock.jsx +5 -0
  231. package/src/components/theme/View/SummaryView.jsx +49 -39
  232. package/src/components/theme/View/TabularView.jsx +59 -53
  233. package/src/components/theme/Widgets/DateWidget.jsx +2 -1
  234. package/src/components/theme/Widgets/DatetimeWidget.jsx +2 -1
  235. package/src/components/theme/Widgets/RelationsWidget.jsx +13 -11
  236. package/src/config/Blocks.jsx +46 -0
  237. package/src/config/Components.jsx +2 -1
  238. package/src/config/ControlPanels.js +2 -0
  239. package/src/config/NonContentRoutes.jsx +1 -0
  240. package/src/config/RichTextEditor/Blocks.jsx +2 -2
  241. package/src/config/RichTextEditor/FromHTML.jsx +2 -2
  242. package/src/config/RichTextEditor/Styles.jsx +1 -1
  243. package/src/config/Widgets.jsx +2 -0
  244. package/src/config/index.js +24 -0
  245. package/src/config/server.js +2 -0
  246. package/src/constants/ActionTypes.js +4 -0
  247. package/src/constants/Indexes.js +3 -1
  248. package/src/constants/Languages.js +8 -4
  249. package/src/express-middleware/devproxy.js +1 -1
  250. package/src/express-middleware/files.js +3 -3
  251. package/src/express-middleware/images.js +4 -4
  252. package/src/express-middleware/ok.js +16 -0
  253. package/src/express-middleware/robotstxt.js +1 -1
  254. package/src/express-middleware/sitemap.js +37 -5
  255. package/src/express-middleware/static.js +3 -3
  256. package/src/helpers/Api/Api.js +1 -1
  257. package/src/helpers/Blocks/Blocks.js +48 -0
  258. package/src/helpers/Blocks/Blocks.test.js +79 -0
  259. package/src/helpers/Extensions/index.js +2 -1
  260. package/src/helpers/Extensions/withBlockSchemaEnhancer.js +15 -11
  261. package/src/helpers/Extensions/withBlockSchemaEnhancer.test.js +145 -0
  262. package/src/helpers/FormValidation/FormValidation.js +40 -2
  263. package/src/helpers/FormValidation/FormValidation.test.js +73 -0
  264. package/src/helpers/Html/Html.jsx +3 -1
  265. package/src/helpers/Html/Html.test.jsx +5 -0
  266. package/src/helpers/MessageLabels/MessageLabels.js +80 -0
  267. package/src/helpers/Robots/Robots.js +24 -6
  268. package/src/helpers/ScrollToTop/ScrollToTop.jsx +5 -3
  269. package/src/helpers/Sitemap/Sitemap.js +44 -2
  270. package/src/helpers/Url/Url.js +49 -7
  271. package/src/helpers/Url/Url.test.js +67 -0
  272. package/src/helpers/Utils/UseDetectClickOutside.stories.jsx +191 -0
  273. package/src/helpers/Utils/Utils.js +63 -13
  274. package/src/helpers/Utils/Utils.test.js +4 -4
  275. package/src/helpers/Utils/usePagination.js +67 -14
  276. package/src/helpers/Utils/usePagination.test.js +115 -0
  277. package/src/helpers/index.js +20 -10
  278. package/src/hooks/client/useClient.js +11 -0
  279. package/src/hooks/clipboard/useClipboard.js +26 -0
  280. package/src/hooks/index.js +2 -0
  281. package/src/icons/grid-block.svg +11 -0
  282. package/src/middleware/Api.test.js +54 -0
  283. package/src/middleware/api.js +24 -6
  284. package/src/middleware/index.js +2 -2
  285. package/src/reducers/actions/actions.js +8 -6
  286. package/src/reducers/actions/actions.test.js +70 -0
  287. package/src/reducers/breadcrumbs/breadcrumbs.js +1 -1
  288. package/src/reducers/index.js +2 -0
  289. package/src/reducers/navigation/navigation.js +1 -1
  290. package/src/reducers/relations/relations.js +173 -0
  291. package/src/reducers/types/types.js +1 -1
  292. package/src/routes.js +14 -0
  293. package/src/server.jsx +28 -23
  294. package/src/start-server.js +2 -2
  295. package/test-setup-config.js +11 -1
  296. package/theme/themes/pastanaga/extras/blocks.less +5 -1
  297. package/theme/themes/pastanaga/extras/contents.less +1 -0
  298. package/theme/themes/pastanaga/extras/grid.less +426 -0
  299. package/theme/themes/pastanaga/extras/main.less +8 -1
  300. package/theme/themes/pastanaga/extras/search.less +6 -0
  301. package/theme/themes/pastanaga/extras/sidebar.less +4 -0
  302. package/theme/themes/pastanaga/extras/toc.less +29 -0
  303. package/theme/themes/pastanaga/extras/userscontrolpanel.less +99 -76
  304. package/.changelog.draft +0 -31
  305. package/.editorconfig +0 -36
  306. package/.storybook/main.js +0 -127
  307. package/.storybook/manager.js +0 -15
  308. package/.storybook/preview.js +0 -21
  309. package/.storybook/static/previewImage.svg +0 -48
  310. package/.yarnrc.yml +0 -5
  311. package/jsdoc.json +0 -16
  312. package/netlify.toml +0 -5
  313. package/pyvenv.cfg +0 -3
  314. package/share/man/man1/ttx.1 +0 -225
  315. package/src/components/manage/Blocks/Teaser/utils.js +0 -44
  316. package/src/components/manage/Blocks/Teaser/utils.test.jsx +0 -229
  317. package/src/components/theme/Header/Header.md +0 -27
  318. package/towncrier.toml +0 -33
@@ -9,8 +9,6 @@ import { listGroups } from '@plone/volto/actions';
9
9
  import { Icon, Toast } from '@plone/volto/components';
10
10
  import { updateGroup, listUsers } from '@plone/volto/actions';
11
11
 
12
- import add from '@plone/volto/icons/add.svg';
13
- import remove from '@plone/volto/icons/remove.svg';
14
12
  import down_key from '@plone/volto/icons/down-key.svg';
15
13
 
16
14
  const ListingTemplate = ({
@@ -116,7 +114,7 @@ const ListingTemplate = ({
116
114
  }
117
115
  }, [dispatch, query_group, show_matrix_options, groups_filter]);
118
116
 
119
- const onSelectOptionHandler = (item, selectedvalue, checked, singleClick) => {
117
+ const onSelectOptionHandler = (selectedvalue, checked, singleClick) => {
120
118
  singleClick = singleClick ?? false;
121
119
  let group = selectedvalue.y;
122
120
  let username = selectedvalue.x;
@@ -150,17 +148,14 @@ const ListingTemplate = ({
150
148
  });
151
149
  };
152
150
 
153
- const onSelectAllHandler = (mtxoption, checked) => {
154
- let elements = document.querySelectorAll(`div.checkbox_${mtxoption} input`);
155
- let identifier;
151
+ const onSelectAllHandler = (group, items_ids, checked) => {
156
152
  let usersgroupmapping = {};
157
- elements.forEach((element) => {
158
- identifier = element.name.split('_-_');
159
- usersgroupmapping[identifier[1]] = checked ? true : false;
153
+ items_ids.forEach((el) => {
154
+ usersgroupmapping[el] = checked ? true : false;
160
155
  });
161
156
 
162
157
  dispatch(
163
- updateGroup(identifier[2], {
158
+ updateGroup(group, {
164
159
  users: usersgroupmapping,
165
160
  }),
166
161
  )
@@ -188,93 +183,68 @@ const ListingTemplate = ({
188
183
  <div className="administration_matrix">
189
184
  {matrix_options && matrix_options?.length > 0 && (
190
185
  <div className="label-options">
191
- {matrix_options?.map((matrix_option) => (
192
- <div
193
- className="label-options-label inclined"
194
- key={matrix_option.value}
195
- >
196
- <div>
197
- <span className="label">{matrix_option.label}</span>
186
+ <div className="target-labels">
187
+ <div>
188
+ <h3>{items.length} users</h3>
189
+ </div>
190
+ <div>
191
+ {matrix_options?.map((matrix_option) => (
192
+ <div
193
+ className="label-options-label inclined"
194
+ key={matrix_option.value}
195
+ >
196
+ <div>
197
+ <span className="label">{matrix_option.label}</span>
198
+ </div>
199
+ </div>
200
+ ))}
201
+ </div>
202
+ </div>
203
+ <div className="listing-row selectall" key="selectall">
204
+ <div className="listing-item">
205
+ <div />
206
+ <div className="matrix_options">
207
+ {matrix_options?.map((matrix_option) => (
208
+ <div key={matrix_option.value}>
209
+ <Checkbox
210
+ className="toggle-target"
211
+ defaultChecked={false}
212
+ onChange={(event, { checked }) =>
213
+ onSelectAllHandler(
214
+ matrix_option.value,
215
+ items.map((el) => el.id),
216
+ checked,
217
+ )
218
+ }
219
+ />
220
+ </div>
221
+ ))}
198
222
  </div>
199
223
  </div>
200
- ))}
224
+ </div>
201
225
  </div>
202
226
  )}
203
227
 
204
228
  <div className="items">
205
229
  {items.length > 0 ? (
206
230
  <>
207
- <div className="listing-row selectall" key="selectall">
208
- <div className="listing-item">
209
- <div />
210
- <div className="matrix_options">
211
- {matrix_options?.map((matrix_option) => (
212
- <div key={matrix_option.value}>
213
- <Button
214
- icon
215
- basic
216
- onClick={() =>
217
- onSelectAllHandler(matrix_option.value, true)
218
- }
219
- className="add-button"
220
- aria-label={
221
- intl.formatMessage(messages.addUsersToGroup) +
222
- ` ${matrix_option.label}`
223
- }
224
- title={
225
- intl.formatMessage(messages.addUsersToGroup) +
226
- ` ${matrix_option.label}`
227
- }
228
- >
229
- <Icon
230
- name={add}
231
- size="10px"
232
- className="circled"
233
- color="unset"
234
- />
235
- </Button>
236
- <Button
237
- icon
238
- basic
239
- onClick={() =>
240
- onSelectAllHandler(matrix_option.value, false)
241
- }
242
- className="remove-button"
243
- aria-label={
244
- intl.formatMessage(messages.removeUsersFromGroup) +
245
- ` ${matrix_option.label}`
246
- }
247
- title={
248
- intl.formatMessage(messages.removeUsersFromGroup) +
249
- ` ${matrix_option.label}`
250
- }
251
- >
252
- <Icon
253
- name={remove}
254
- size="10px"
255
- className="circled"
256
- color="unset"
257
- />
258
- </Button>
259
- </div>
260
- ))}
261
- </div>
262
- </div>
263
- </div>
264
-
265
- <h3>{items.length} users </h3>
266
231
  {items.map((item) => (
267
- <div className="listing-row" key={item.id}>
232
+ <div
233
+ className="listing-row"
234
+ key={item.id}
235
+ id={`source-row-${item.id}`}
236
+ >
268
237
  <div className="listing-item" key={item['@id']}>
269
238
  <div>
270
- <h4>
271
- {item.fullname} ({item.id})
239
+ <h4 title={`${item.fullname} ${item.id}`}>
240
+ {item.fullname?.length > 25
241
+ ? item.fullname.slice(0, 22) + '...'
242
+ : item.fullname || item.id}
272
243
  </h4>
273
244
  </div>
274
245
  <div className="matrix_options">
275
246
  {matrix_options?.map((matrix_option) => (
276
247
  <Checkbox
277
- name={`member_-_${item.id}_-_${matrix_option.value}`}
278
248
  className={`checkbox_${matrix_option.value}`}
279
249
  key={matrix_option.value}
280
250
  title={matrix_option.title}
@@ -283,7 +253,6 @@ const ListingTemplate = ({
283
253
  .includes(matrix_option.value)}
284
254
  onChange={(event, { checked }) => {
285
255
  onSelectOptionHandler(
286
- item,
287
256
  { y: matrix_option.value, x: item.id },
288
257
  checked,
289
258
  true,
@@ -122,83 +122,87 @@ const UserGroupMembershipMatrix = ({ many_users, many_groups }) => {
122
122
 
123
123
  return (
124
124
  <div className="controlpanel_matrix">
125
- <div className="controlpanel_search_y">
126
- <Form className="search_users" onSubmit={onReset}>
127
- <Form.Field>
128
- <Input
129
- name="SearchUser"
130
- action={{ icon: 'delete' }}
131
- placeholder={intl.formatMessage(messages.searchUsers)}
132
- onChange={onChangeSearchUsers}
133
- onKeyDown={onChangeSearchUsers}
134
- id="user-search-input"
135
- />
136
- </Form.Field>
137
- </Form>
125
+ <div className="controlpanel_search_wrapper">
126
+ <div className="controlpanel_search_y">
127
+ <Form className="search_users" onSubmit={onReset}>
128
+ <Form.Field>
129
+ <Input
130
+ name="SearchUser"
131
+ action={{ icon: 'delete' }}
132
+ placeholder={intl.formatMessage(messages.searchUsers)}
133
+ onChange={onChangeSearchUsers}
134
+ onKeyDown={onChangeSearchUsers}
135
+ id="user-search-input"
136
+ />
137
+ </Form.Field>
138
+ </Form>
139
+ </div>
140
+ <div className="controlpanel_search_x">
141
+ <Form className="search_groups" onSubmit={onReset}>
142
+ <Form.Field>
143
+ <Input
144
+ name="SearchGroup"
145
+ action={{ icon: 'delete' }}
146
+ placeholder={intl.formatMessage(messages.searchGroups)}
147
+ onChange={onChangeSearchGroups}
148
+ onKeyDown={onChangeSearchGroups}
149
+ id="group-search-input"
150
+ />
151
+ </Form.Field>
152
+ <Form.Field>
153
+ <Checkbox
154
+ name="addJoinedGroups"
155
+ label={intl.formatMessage(messages.addJoinedGroups)}
156
+ title={intl.formatMessage(messages.addJoinedGroups)}
157
+ defaultChecked={false}
158
+ onChange={(event, { checked }) => {
159
+ onToggleJoinedGroups(checked);
160
+ }}
161
+ />
162
+ </Form.Field>
163
+ </Form>
164
+ </div>
138
165
  </div>
139
- <div className="controlpanel_search_x">
140
- <Form className="search_groups" onSubmit={onReset}>
141
- <Form.Field>
142
- <Input
143
- name="SearchGroup"
144
- action={{ icon: 'delete' }}
145
- placeholder={intl.formatMessage(messages.searchGroups)}
146
- onChange={onChangeSearchGroups}
147
- onKeyDown={onChangeSearchGroups}
148
- id="group-search-input"
149
- />
150
- </Form.Field>
151
- <Form.Field>
152
- <Checkbox
153
- name="addJoinedGroups"
154
- label={intl.formatMessage(messages.addJoinedGroups)}
155
- title={intl.formatMessage(messages.addJoinedGroups)}
156
- defaultChecked={false}
157
- onChange={(event, { checked }) => {
158
- onToggleJoinedGroups(checked);
159
- }}
160
- />
161
- </Form.Field>
162
- </Form>
166
+ <div className="controlpanel_listing_wrapper">
167
+ <div className="controlpanel_filter">
168
+ <h3>{intl.formatMessage(messages.filterByGroups)}</h3>
169
+ <Form className="search_filter_groups" onSubmit={onReset}>
170
+ <Form.Field>
171
+ <Input
172
+ name="SearchGroupFilter"
173
+ action={{ icon: 'delete' }}
174
+ placeholder={intl.formatMessage(messages.searchGroups)}
175
+ onChange={onChangeSearchGroupsFilter}
176
+ onKeyDown={onChangeSearchGroupsFilter}
177
+ id="groupfilter-search-input"
178
+ />
179
+ </Form.Field>
180
+ </Form>
181
+ {(!many_groups || query_group_filter.length > 1) &&
182
+ filter_options?.map((filter_option) => (
183
+ <Form.Field>
184
+ <Checkbox
185
+ name={`filter_option_${filter_option.value}`}
186
+ key={filter_option.value}
187
+ title={filter_option.label}
188
+ label={filter_option.label}
189
+ defaultChecked={false}
190
+ onChange={(event, { checked }) => {
191
+ onSelectOptionHandler(filter_option, checked);
192
+ }}
193
+ />
194
+ </Form.Field>
195
+ ))}
196
+ </div>
197
+ <UserGroupMembershipListing
198
+ query_user={query_user}
199
+ query_group={query_group}
200
+ groups_filter={groups_filter}
201
+ add_joined_groups={add_joined_groups}
202
+ many_users={many_users}
203
+ many_groups={many_groups}
204
+ />
163
205
  </div>
164
- <div className="controlpanel_filter">
165
- <h3>{intl.formatMessage(messages.filterByGroups)}</h3>
166
-
167
- <Form className="search_filter_groups" onSubmit={onReset}>
168
- <Form.Field>
169
- <Input
170
- name="SearchGroupFilter"
171
- action={{ icon: 'delete' }}
172
- placeholder={intl.formatMessage(messages.searchGroups)}
173
- onChange={onChangeSearchGroupsFilter}
174
- onKeyDown={onChangeSearchGroupsFilter}
175
- id="groupfilter-search-input"
176
- />
177
- </Form.Field>
178
- </Form>
179
-
180
- {(!many_groups || query_group_filter.length > 1) &&
181
- filter_options?.map((filter_option) => (
182
- <Checkbox
183
- name={`filter_option_${filter_option.value}`}
184
- key={filter_option.value}
185
- title={filter_option.label}
186
- label={filter_option.label}
187
- defaultChecked={false}
188
- onChange={(event, { checked }) => {
189
- onSelectOptionHandler(filter_option, checked);
190
- }}
191
- />
192
- ))}
193
- </div>
194
- <UserGroupMembershipListing
195
- query_user={query_user}
196
- query_group={query_group}
197
- groups_filter={groups_filter}
198
- add_joined_groups={add_joined_groups}
199
- many_users={many_users}
200
- many_groups={many_groups}
201
- />
202
206
  </div>
203
207
  );
204
208
  };
@@ -53,6 +53,7 @@ const DragDropList = (props) => {
53
53
  const {
54
54
  childList,
55
55
  children,
56
+ direction = 'vertical',
56
57
  onMoveItem,
57
58
  as = 'div',
58
59
  style,
@@ -128,6 +129,7 @@ const DragDropList = (props) => {
128
129
  >
129
130
  <Droppable
130
131
  droppableId={uid}
132
+ direction={direction}
131
133
  renderClone={(provided, snapshot, rubric) => {
132
134
  const index = rubric.source.index;
133
135
  return children({
@@ -160,19 +162,22 @@ const DragDropList = (props) => {
160
162
  </Draggable>
161
163
  ))}
162
164
  {provided.placeholder}
163
- {!isEmpty(placeholderProps) && snapshot.isDraggingOver && (
164
- <div
165
- style={{
166
- position: 'absolute',
167
- top: placeholderProps.clientY,
168
- left: placeholderProps.clientX,
169
- height: placeholderProps.clientHeight,
170
- background: '#eee',
171
- width: placeholderProps.clientWidth,
172
- borderRadius: '3px',
173
- }}
174
- />
175
- )}
165
+ {/* TODO: Fix the ghost problem if horizontal dnd is present */}
166
+ {direction !== 'horizontal' &&
167
+ !isEmpty(placeholderProps) &&
168
+ snapshot.isDraggingOver && (
169
+ <div
170
+ style={{
171
+ position: 'absolute',
172
+ top: placeholderProps.clientY,
173
+ left: placeholderProps.clientX,
174
+ height: placeholderProps.clientHeight,
175
+ background: '#eee',
176
+ width: placeholderProps.clientWidth,
177
+ borderRadius: '3px',
178
+ }}
179
+ />
180
+ )}
176
181
  </AsDomComponent>
177
182
  )}
178
183
  </Droppable>
@@ -31,7 +31,7 @@ import { Portal } from 'react-portal';
31
31
  import { connect } from 'react-redux';
32
32
  import {
33
33
  Button,
34
- Container,
34
+ Container as SemanticContainer,
35
35
  Form as UiForm,
36
36
  Message,
37
37
  Segment,
@@ -545,12 +545,14 @@ class Form extends Component {
545
545
  const { schema: originalSchema, onCancel, onSubmit } = this.props;
546
546
  const { formData } = this.state;
547
547
  const schema = this.removeBlocksLayoutFields(originalSchema);
548
+ const Container =
549
+ config.getComponent({ name: 'Container' }).component || SemanticContainer;
548
550
 
549
551
  return this.props.visual ? (
550
552
  // Removing this from SSR is important, since react-beautiful-dnd supports SSR,
551
553
  // but draftJS don't like it much and the hydration gets messed up
552
554
  this.state.isClient && (
553
- <div className="ui container">
555
+ <Container>
554
556
  <BlocksToolbar
555
557
  formData={this.state.formData}
556
558
  selectedBlock={this.state.selected}
@@ -639,7 +641,7 @@ class Form extends Component {
639
641
  </UiForm>
640
642
  </Portal>
641
643
  )}
642
- </div>
644
+ </Container>
643
645
  )
644
646
  ) : (
645
647
  <Container>
@@ -4,13 +4,21 @@ import { Accordion, Segment, Message } from 'semantic-ui-react';
4
4
  import { defineMessages, injectIntl } from 'react-intl';
5
5
  import AnimateHeight from 'react-animate-height';
6
6
  import { keys, map, isEqual } from 'lodash';
7
-
7
+ import { useAtom } from 'jotai';
8
+ import { inlineFormFieldsetsState } from './InlineFormState';
9
+ import {
10
+ insertInArray,
11
+ removeFromArray,
12
+ arrayRange,
13
+ } from '@plone/volto/helpers/Utils/Utils';
8
14
  import { Field, Icon } from '@plone/volto/components';
9
15
  import { applySchemaDefaults } from '@plone/volto/helpers';
10
16
 
11
17
  import upSVG from '@plone/volto/icons/up-key.svg';
12
18
  import downSVG from '@plone/volto/icons/down-key.svg';
13
19
 
20
+ import config from '@plone/volto/registry';
21
+
14
22
  const messages = defineMessages({
15
23
  editValues: {
16
24
  id: 'Edit values',
@@ -70,12 +78,34 @@ const InlineForm = (props) => {
70
78
  // eslint-disable-next-line react-hooks/exhaustive-deps
71
79
  }, []);
72
80
 
73
- const [currentActiveFieldset, setCurrentActiveFieldset] = React.useState(0);
81
+ const [currentActiveFieldset, setCurrentActiveFieldset] = useAtom(
82
+ inlineFormFieldsetsState({
83
+ name: block,
84
+ fielsetList: other,
85
+ initialState: config.settings.blockSettingsTabFieldsetsInitialStateOpen
86
+ ? arrayRange(0, other.length - 1, 1)
87
+ : [],
88
+ }),
89
+ );
90
+
74
91
  function handleCurrentActiveFieldset(e, blockProps) {
75
92
  const { index } = blockProps;
76
- const newIndex = currentActiveFieldset === index ? -1 : index;
77
-
78
- setCurrentActiveFieldset(newIndex);
93
+ if (currentActiveFieldset.includes(index)) {
94
+ setCurrentActiveFieldset(
95
+ removeFromArray(
96
+ currentActiveFieldset,
97
+ currentActiveFieldset.indexOf(index),
98
+ ),
99
+ );
100
+ } else {
101
+ setCurrentActiveFieldset(
102
+ insertInArray(
103
+ currentActiveFieldset,
104
+ index,
105
+ currentActiveFieldset.length + 1,
106
+ ),
107
+ );
108
+ }
79
109
  }
80
110
 
81
111
  return (
@@ -136,22 +166,22 @@ const InlineForm = (props) => {
136
166
  <Accordion fluid styled className="form" key={fieldset.id}>
137
167
  <div key={fieldset.id} id={`blockform-fieldset-${fieldset.id}`}>
138
168
  <Accordion.Title
139
- active={currentActiveFieldset === index}
169
+ active={currentActiveFieldset.includes(index)}
140
170
  index={index}
141
171
  onClick={handleCurrentActiveFieldset}
142
172
  >
143
173
  {fieldset.title && <>{fieldset.title}</>}
144
- {currentActiveFieldset === index ? (
174
+ {currentActiveFieldset.includes(index) ? (
145
175
  <Icon name={upSVG} size="20px" />
146
176
  ) : (
147
177
  <Icon name={downSVG} size="20px" />
148
178
  )}
149
179
  </Accordion.Title>
150
- <Accordion.Content active={currentActiveFieldset === index}>
180
+ <Accordion.Content active={currentActiveFieldset.includes(index)}>
151
181
  <AnimateHeight
152
182
  animateOpacity
153
183
  duration={500}
154
- height={currentActiveFieldset === index ? 'auto' : 0}
184
+ height={currentActiveFieldset.includes(index) ? 'auto' : 0}
155
185
  >
156
186
  <Segment className="attached">
157
187
  {map(fieldset.fields, (field) => (
@@ -0,0 +1,8 @@
1
+ import { atom } from 'jotai';
2
+ import { atomFamily } from 'jotai/utils';
3
+ import { isEqual } from 'lodash';
4
+
5
+ export const inlineFormFieldsetsState = atomFamily(
6
+ ({ name, initialState }) => atom(initialState),
7
+ (a, b) => a.name === b.name && isEqual(a.fielsetList, b.fielsetList),
8
+ );
@@ -9,7 +9,13 @@ import { Helmet } from '@plone/volto/helpers';
9
9
  import { Link } from 'react-router-dom';
10
10
  import { connect } from 'react-redux';
11
11
  import { compose } from 'redux';
12
- import { Container, Dropdown, Icon, Segment, Table } from 'semantic-ui-react';
12
+ import {
13
+ Container as SemanticContainer,
14
+ Dropdown,
15
+ Icon,
16
+ Segment,
17
+ Table,
18
+ } from 'semantic-ui-react';
13
19
  import { concat, map, reverse, find } from 'lodash';
14
20
  import { Portal } from 'react-portal';
15
21
  import { FormattedMessage, defineMessages, injectIntl } from 'react-intl';
@@ -24,6 +30,7 @@ import {
24
30
  } from '@plone/volto/components';
25
31
  import { getHistory, revertHistory, listActions } from '@plone/volto/actions';
26
32
  import { getBaseUrl } from '@plone/volto/helpers';
33
+ import config from '@plone/volto/registry';
27
34
 
28
35
  import backSVG from '@plone/volto/icons/back.svg';
29
36
 
@@ -147,6 +154,9 @@ class History extends Component {
147
154
  });
148
155
  const entries = this.processHistoryEntries();
149
156
 
157
+ const Container =
158
+ config.getComponent({ name: 'Container' }).component || SemanticContainer;
159
+
150
160
  return !historyAction ? (
151
161
  <>
152
162
  {this.props.token ? (