@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
@@ -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 ? (