@plone/volto 17.0.0-alpha.3 → 17.0.0-alpha.30

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