@akemona-org/strapi-plugin-content-manager 3.7.0

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 (401) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +27 -0
  3. package/admin/src/InjectedComponents/ContentTypeBuilder/ConfigureViewButton/index.js +78 -0
  4. package/admin/src/assets/images/background_input.svg +1 -0
  5. package/admin/src/assets/images/icon-cross-blue.svg +1 -0
  6. package/admin/src/assets/images/icon_remove.svg +19 -0
  7. package/admin/src/assets/images/logo.svg +1 -0
  8. package/admin/src/components/AddDropdown/components.js +113 -0
  9. package/admin/src/components/AddDropdown/index.js +76 -0
  10. package/admin/src/components/Block/components.js +28 -0
  11. package/admin/src/components/Block/index.js +45 -0
  12. package/admin/src/components/ComponentInitializer/P.js +9 -0
  13. package/admin/src/components/ComponentInitializer/index.js +43 -0
  14. package/admin/src/components/Container/index.js +7 -0
  15. package/admin/src/components/CustomInputCheckbox/components.js +77 -0
  16. package/admin/src/components/CustomInputCheckbox/index.js +53 -0
  17. package/admin/src/components/CustomTable/ActionCollapse/Delete.js +14 -0
  18. package/admin/src/components/CustomTable/ActionCollapse/DeleteAll.js +18 -0
  19. package/admin/src/components/CustomTable/ActionCollapse/Wrapper.js +20 -0
  20. package/admin/src/components/CustomTable/ActionCollapse/index.js +38 -0
  21. package/admin/src/components/CustomTable/Headers/Header.js +59 -0
  22. package/admin/src/components/CustomTable/Headers/Thead.js +35 -0
  23. package/admin/src/components/CustomTable/Headers/index.js +46 -0
  24. package/admin/src/components/CustomTable/Row/ActionContainer.js +19 -0
  25. package/admin/src/components/CustomTable/Row/Cell.js +55 -0
  26. package/admin/src/components/CustomTable/Row/index.js +112 -0
  27. package/admin/src/components/CustomTable/index.js +162 -0
  28. package/admin/src/components/CustomTable/styledComponents.js +85 -0
  29. package/admin/src/components/DragLayer/index.js +102 -0
  30. package/admin/src/components/DraggedField/Close/index.js +10 -0
  31. package/admin/src/components/DraggedField/GrabWrapper.js +38 -0
  32. package/admin/src/components/DraggedField/Link.js +17 -0
  33. package/admin/src/components/DraggedField/NameWrapper.js +29 -0
  34. package/admin/src/components/DraggedField/RemoveWrapper.js +32 -0
  35. package/admin/src/components/DraggedField/SubWrapper.js +36 -0
  36. package/admin/src/components/DraggedField/Wrapper.js +134 -0
  37. package/admin/src/components/DraggedField/index.js +196 -0
  38. package/admin/src/components/DraggedField/utils/getColor.js +12 -0
  39. package/admin/src/components/DraggedField/utils/getHeight.js +3 -0
  40. package/admin/src/components/DraggedFieldWithPreview/Carret.js +24 -0
  41. package/admin/src/components/DraggedFieldWithPreview/DynamicComponent.js +70 -0
  42. package/admin/src/components/DraggedFieldWithPreview/DynamicZoneWrapper.js +10 -0
  43. package/admin/src/components/DraggedFieldWithPreview/Tooltip.js +19 -0
  44. package/admin/src/components/DraggedFieldWithPreview/Wrapper.js +24 -0
  45. package/admin/src/components/DraggedFieldWithPreview/index.js +194 -0
  46. package/admin/src/components/DynamicComponentCard/Wrapper.js +63 -0
  47. package/admin/src/components/DynamicComponentCard/index.js +49 -0
  48. package/admin/src/components/DynamicZone/BaselineAlignement.js +11 -0
  49. package/admin/src/components/DynamicZone/Button.js +31 -0
  50. package/admin/src/components/DynamicZone/Component/RoundCTA.js +45 -0
  51. package/admin/src/components/DynamicZone/Component/index.js +79 -0
  52. package/admin/src/components/DynamicZone/ComponentWrapper.js +44 -0
  53. package/admin/src/components/DynamicZone/DynamicZoneWrapper.js +12 -0
  54. package/admin/src/components/DynamicZone/Label.js +42 -0
  55. package/admin/src/components/DynamicZone/Picker/Category/Banner/Wrapper.js +78 -0
  56. package/admin/src/components/DynamicZone/Picker/Category/Banner/index.js +33 -0
  57. package/admin/src/components/DynamicZone/Picker/Category/index.js +53 -0
  58. package/admin/src/components/DynamicZone/Picker/Wrapper.js +32 -0
  59. package/admin/src/components/DynamicZone/Picker/index.js +88 -0
  60. package/admin/src/components/DynamicZone/Wrapper.js +34 -0
  61. package/admin/src/components/DynamicZone/index.js +238 -0
  62. package/admin/src/components/DynamicZone/utils/connect.js +12 -0
  63. package/admin/src/components/DynamicZone/utils/select.js +49 -0
  64. package/admin/src/components/FieldComponent/ComponentIcon.js +44 -0
  65. package/admin/src/components/FieldComponent/EmptyComponent.js +19 -0
  66. package/admin/src/components/FieldComponent/Label.js +10 -0
  67. package/admin/src/components/FieldComponent/ResetComponent.js +41 -0
  68. package/admin/src/components/FieldComponent/Wrapper.js +18 -0
  69. package/admin/src/components/FieldComponent/index.js +171 -0
  70. package/admin/src/components/FieldComponent/utils/connect.js +12 -0
  71. package/admin/src/components/FieldComponent/utils/select.js +123 -0
  72. package/admin/src/components/FieldsReorder/Item.js +249 -0
  73. package/admin/src/components/FieldsReorder/components.js +8 -0
  74. package/admin/src/components/FieldsReorder/index.js +102 -0
  75. package/admin/src/components/FilterOptionsCTA/index.js +14 -0
  76. package/admin/src/components/FilterPicker/components.js +56 -0
  77. package/admin/src/components/FilterPicker/index.js +258 -0
  78. package/admin/src/components/FilterPicker/init.js +25 -0
  79. package/admin/src/components/FilterPicker/reducer.js +58 -0
  80. package/admin/src/components/FilterPickerOption/Input.js +58 -0
  81. package/admin/src/components/FilterPickerOption/Option.js +18 -0
  82. package/admin/src/components/FilterPickerOption/components.js +60 -0
  83. package/admin/src/components/FilterPickerOption/index.js +101 -0
  84. package/admin/src/components/FormTitle/index.js +26 -0
  85. package/admin/src/components/FormWrapper/index.js +20 -0
  86. package/admin/src/components/InputJSON/components.js +30 -0
  87. package/admin/src/components/InputJSON/index.js +184 -0
  88. package/admin/src/components/InputJSON/jsonlint.js +424 -0
  89. package/admin/src/components/InputJSONWithErrors/Wrapper.js +32 -0
  90. package/admin/src/components/InputJSONWithErrors/index.js +168 -0
  91. package/admin/src/components/InputUID/InputUID.js +26 -0
  92. package/admin/src/components/InputUID/Options/Option.js +22 -0
  93. package/admin/src/components/InputUID/Options/OptionsTitle.js +12 -0
  94. package/admin/src/components/InputUID/Options/RightOptionLabel.js +10 -0
  95. package/admin/src/components/InputUID/Options/index.js +34 -0
  96. package/admin/src/components/InputUID/Options/wrapper.js +13 -0
  97. package/admin/src/components/InputUID/RegenerateButton.js +18 -0
  98. package/admin/src/components/InputUID/RightContent.js +14 -0
  99. package/admin/src/components/InputUID/RightContentLabel.js +10 -0
  100. package/admin/src/components/InputUID/RightLabel.js +42 -0
  101. package/admin/src/components/InputUID/SubLabel.js +9 -0
  102. package/admin/src/components/InputUID/Wrapper.js +8 -0
  103. package/admin/src/components/InputUID/index.js +325 -0
  104. package/admin/src/components/InputUID/regex.js +3 -0
  105. package/admin/src/components/Inputs/index.js +283 -0
  106. package/admin/src/components/Inputs/utils/VALIDATIONS_TO_OMIT.js +12 -0
  107. package/admin/src/components/Inputs/utils/connect.js +12 -0
  108. package/admin/src/components/Inputs/utils/generateOptions.js +19 -0
  109. package/admin/src/components/Inputs/utils/getInputType.js +44 -0
  110. package/admin/src/components/Inputs/utils/getStep.js +15 -0
  111. package/admin/src/components/Inputs/utils/index.js +6 -0
  112. package/admin/src/components/Inputs/utils/select.js +38 -0
  113. package/admin/src/components/LayoutTitle/index.js +19 -0
  114. package/admin/src/components/MediaPreviewList/StyledMediaPreviewList.js +171 -0
  115. package/admin/src/components/MediaPreviewList/index.js +110 -0
  116. package/admin/src/components/NonRepeatableComponent/index.js +73 -0
  117. package/admin/src/components/NonRepeatableWrapper/index.js +73 -0
  118. package/admin/src/components/PlusButton/index.js +52 -0
  119. package/admin/src/components/PopupForm/index.js +93 -0
  120. package/admin/src/components/PreviewCarret/components.js +27 -0
  121. package/admin/src/components/PreviewCarret/index.js +22 -0
  122. package/admin/src/components/PreviewWysiwyg/Wrapper.js +133 -0
  123. package/admin/src/components/PreviewWysiwyg/index.js +34 -0
  124. package/admin/src/components/PreviewWysiwyg/utils/mdRenderer.js +72 -0
  125. package/admin/src/components/PreviewWysiwyg/utils/satinizeHtml.js +16 -0
  126. package/admin/src/components/RelationPreviewList/CountWrapper.js +7 -0
  127. package/admin/src/components/RelationPreviewList/RelationPreviewTooltip.js +117 -0
  128. package/admin/src/components/RelationPreviewList/index.js +111 -0
  129. package/admin/src/components/RepeatableComponent/AddFieldButton.js +64 -0
  130. package/admin/src/components/RepeatableComponent/Banner.js +112 -0
  131. package/admin/src/components/RepeatableComponent/BannerWrapper.js +194 -0
  132. package/admin/src/components/RepeatableComponent/CarretTop.js +14 -0
  133. package/admin/src/components/RepeatableComponent/DraggedItem/index.js +245 -0
  134. package/admin/src/components/RepeatableComponent/DraggedItem/utils/connect.js +11 -0
  135. package/admin/src/components/RepeatableComponent/DraggedItem/utils/index.js +2 -0
  136. package/admin/src/components/RepeatableComponent/DraggedItem/utils/select.js +30 -0
  137. package/admin/src/components/RepeatableComponent/EmptyComponent.js +27 -0
  138. package/admin/src/components/RepeatableComponent/FormWrapper.js +27 -0
  139. package/admin/src/components/RepeatableComponent/index.js +187 -0
  140. package/admin/src/components/RepeatableComponent/reducer.js +73 -0
  141. package/admin/src/components/RepeatableComponent/utils/connect.js +11 -0
  142. package/admin/src/components/RepeatableComponent/utils/select.js +12 -0
  143. package/admin/src/components/Search/index.js +88 -0
  144. package/admin/src/components/SectionTitle/Title.js +11 -0
  145. package/admin/src/components/SectionTitle/index.js +29 -0
  146. package/admin/src/components/SelectMany/ListItem.js +107 -0
  147. package/admin/src/components/SelectMany/Relation.js +106 -0
  148. package/admin/src/components/SelectMany/components.js +153 -0
  149. package/admin/src/components/SelectMany/index.js +159 -0
  150. package/admin/src/components/SelectOne/SingleValue.js +58 -0
  151. package/admin/src/components/SelectOne/index.js +71 -0
  152. package/admin/src/components/SelectWrapper/ClearIndicator.js +15 -0
  153. package/admin/src/components/SelectWrapper/IndicatorSeparator.js +3 -0
  154. package/admin/src/components/SelectWrapper/Option.js +76 -0
  155. package/admin/src/components/SelectWrapper/components.js +14 -0
  156. package/admin/src/components/SelectWrapper/index.js +393 -0
  157. package/admin/src/components/SelectWrapper/utils/connect.js +12 -0
  158. package/admin/src/components/SelectWrapper/utils/index.js +3 -0
  159. package/admin/src/components/SelectWrapper/utils/select.js +45 -0
  160. package/admin/src/components/SelectWrapper/utils/styles.js +105 -0
  161. package/admin/src/components/Separator/index.js +9 -0
  162. package/admin/src/components/SettingFormWrapper/index.js +9 -0
  163. package/admin/src/components/SettingsViewWrapper/index.js +283 -0
  164. package/admin/src/components/SortWrapper/index.js +9 -0
  165. package/admin/src/components/SortableList/Item.js +126 -0
  166. package/admin/src/components/SortableList/index.js +60 -0
  167. package/admin/src/components/State/Wrapper.js +30 -0
  168. package/admin/src/components/State/index.js +26 -0
  169. package/admin/src/components/Truncate/index.js +5 -0
  170. package/admin/src/components/Truncated/index.js +10 -0
  171. package/admin/src/components/Wysiwyg/EditorWrapper.js +122 -0
  172. package/admin/src/components/Wysiwyg/MediaLib.js +71 -0
  173. package/admin/src/components/Wysiwyg/PreviewControlWrapper.js +30 -0
  174. package/admin/src/components/Wysiwyg/SelectWrapper.js +24 -0
  175. package/admin/src/components/Wysiwyg/ToggleModeWrapper.js +30 -0
  176. package/admin/src/components/Wysiwyg/constants.js +98 -0
  177. package/admin/src/components/Wysiwyg/customSelect.js +39 -0
  178. package/admin/src/components/Wysiwyg/helpers.js +116 -0
  179. package/admin/src/components/Wysiwyg/index.js +819 -0
  180. package/admin/src/components/Wysiwyg/previewControl.js +29 -0
  181. package/admin/src/components/Wysiwyg/toggleMode.js +44 -0
  182. package/admin/src/components/Wysiwyg/utils.js +70 -0
  183. package/admin/src/components/WysiwygBottomControls/components.js +44 -0
  184. package/admin/src/components/WysiwygBottomControls/index.js +33 -0
  185. package/admin/src/components/WysiwygDropUpload/Label.js +16 -0
  186. package/admin/src/components/WysiwygDropUpload/index.js +18 -0
  187. package/admin/src/components/WysiwygEditor/index.js +26 -0
  188. package/admin/src/components/WysiwygInlineControls/Button.js +77 -0
  189. package/admin/src/components/WysiwygInlineControls/StyledButton.js +54 -0
  190. package/admin/src/components/WysiwygInlineControls/Wrapper.js +25 -0
  191. package/admin/src/components/WysiwygInlineControls/index.js +66 -0
  192. package/admin/src/components/WysiwygWithErrors/Wrapper.js +38 -0
  193. package/admin/src/components/WysiwygWithErrors/index.js +158 -0
  194. package/admin/src/containers/CollectionTypeFormWrapper/index.js +376 -0
  195. package/admin/src/containers/CollectionTypeFormWrapper/utils/getRequestUrl.js +5 -0
  196. package/admin/src/containers/CollectionTypeFormWrapper/utils/index.js +2 -0
  197. package/admin/src/containers/CollectionTypeRecursivePath/index.js +125 -0
  198. package/admin/src/containers/ComponentSetttingsView/index.js +55 -0
  199. package/admin/src/containers/EditSettingsView/index.js +408 -0
  200. package/admin/src/containers/EditSettingsView/init.js +18 -0
  201. package/admin/src/containers/EditSettingsView/reducer.js +126 -0
  202. package/admin/src/containers/EditSettingsView/utils/createPossibleMainFieldsForModelsAndComponents.js +26 -0
  203. package/admin/src/containers/EditSettingsView/utils/getInputProps.js +30 -0
  204. package/admin/src/containers/EditSettingsView/utils/index.js +2 -0
  205. package/admin/src/containers/EditSettingsView/utils/layout.js +98 -0
  206. package/admin/src/containers/EditView/DeleteLink/index.js +94 -0
  207. package/admin/src/containers/EditView/DeleteLink/utils/connect.js +12 -0
  208. package/admin/src/containers/EditView/DeleteLink/utils/index.js +2 -0
  209. package/admin/src/containers/EditView/DeleteLink/utils/select.js +21 -0
  210. package/admin/src/containers/EditView/Header/index.js +258 -0
  211. package/admin/src/containers/EditView/Header/utils/connect.js +12 -0
  212. package/admin/src/containers/EditView/Header/utils/getDraftRelations.js +62 -0
  213. package/admin/src/containers/EditView/Header/utils/index.js +3 -0
  214. package/admin/src/containers/EditView/Header/utils/select.js +31 -0
  215. package/admin/src/containers/EditView/InformationCard.js +100 -0
  216. package/admin/src/containers/EditView/components.js +74 -0
  217. package/admin/src/containers/EditView/index.js +297 -0
  218. package/admin/src/containers/EditView/utils/createAttributesLayout.js +39 -0
  219. package/admin/src/containers/EditView/utils/getFieldsActionMatchingPermissions.js +23 -0
  220. package/admin/src/containers/EditView/utils/index.js +3 -0
  221. package/admin/src/containers/EditViewDataManagerProvider/index.js +519 -0
  222. package/admin/src/containers/EditViewDataManagerProvider/reducer.js +218 -0
  223. package/admin/src/containers/EditViewDataManagerProvider/utils/cleanData.js +88 -0
  224. package/admin/src/containers/EditViewDataManagerProvider/utils/getYupInnerErrors.js +17 -0
  225. package/admin/src/containers/EditViewDataManagerProvider/utils/index.js +3 -0
  226. package/admin/src/containers/EditViewDataManagerProvider/utils/schema.js +368 -0
  227. package/admin/src/containers/EditViewLayoutManager/Permissions.js +30 -0
  228. package/admin/src/containers/EditViewLayoutManager/actions.js +9 -0
  229. package/admin/src/containers/EditViewLayoutManager/constants.js +2 -0
  230. package/admin/src/containers/EditViewLayoutManager/index.js +44 -0
  231. package/admin/src/containers/EditViewLayoutManager/reducer.js +30 -0
  232. package/admin/src/containers/EditViewLayoutManager/selectors.js +5 -0
  233. package/admin/src/containers/LayoutDndProvider/index.js +75 -0
  234. package/admin/src/containers/ListSettingsView/DragWrapper.js +21 -0
  235. package/admin/src/containers/ListSettingsView/DropdownButton.js +8 -0
  236. package/admin/src/containers/ListSettingsView/Label.js +91 -0
  237. package/admin/src/containers/ListSettingsView/MenuDropdown.js +41 -0
  238. package/admin/src/containers/ListSettingsView/Toggle.js +51 -0
  239. package/admin/src/containers/ListSettingsView/forms.json +64 -0
  240. package/admin/src/containers/ListSettingsView/index.js +298 -0
  241. package/admin/src/containers/ListSettingsView/init.js +11 -0
  242. package/admin/src/containers/ListSettingsView/reducer.js +77 -0
  243. package/admin/src/containers/ListView/FieldPicker/ConfigureLink/StyledLink.js +28 -0
  244. package/admin/src/containers/ListView/FieldPicker/ConfigureLink/Wrapper.js +8 -0
  245. package/admin/src/containers/ListView/FieldPicker/ConfigureLink/index.js +29 -0
  246. package/admin/src/containers/ListView/FieldPicker/Field/Wrapper.js +15 -0
  247. package/admin/src/containers/ListView/FieldPicker/Field/index.js +24 -0
  248. package/admin/src/containers/ListView/FieldPicker/Fields/Wrapper.js +18 -0
  249. package/admin/src/containers/ListView/FieldPicker/Fields/index.js +27 -0
  250. package/admin/src/containers/ListView/FieldPicker/Header/Reset.js +8 -0
  251. package/admin/src/containers/ListView/FieldPicker/Header/index.js +42 -0
  252. package/admin/src/containers/ListView/FieldPicker/Wrapper.js +9 -0
  253. package/admin/src/containers/ListView/FieldPicker/index.js +46 -0
  254. package/admin/src/containers/ListView/Filter.js +83 -0
  255. package/admin/src/containers/ListView/Footer.js +60 -0
  256. package/admin/src/containers/ListView/actions.js +91 -0
  257. package/admin/src/containers/ListView/components.js +138 -0
  258. package/admin/src/containers/ListView/constants.js +16 -0
  259. package/admin/src/containers/ListView/index.js +573 -0
  260. package/admin/src/containers/ListView/reducer.js +182 -0
  261. package/admin/src/containers/ListView/selectors.js +24 -0
  262. package/admin/src/containers/ListView/utils/buildQueryString.js +26 -0
  263. package/admin/src/containers/ListView/utils/createPluginsFilter.js +13 -0
  264. package/admin/src/containers/ListView/utils/getAllAllowedHeaders.js +17 -0
  265. package/admin/src/containers/ListView/utils/getFirstSortableHeader.js +14 -0
  266. package/admin/src/containers/ListView/utils/index.js +3 -0
  267. package/admin/src/containers/ListViewLayoutManager/Permissions.js +29 -0
  268. package/admin/src/containers/ListViewLayoutManager/index.js +60 -0
  269. package/admin/src/containers/ListViewProvider/index.js +16 -0
  270. package/admin/src/containers/Main/actions.js +13 -0
  271. package/admin/src/containers/Main/constants.js +3 -0
  272. package/admin/src/containers/Main/index.js +100 -0
  273. package/admin/src/containers/Main/reducer.js +37 -0
  274. package/admin/src/containers/Main/selectors.js +20 -0
  275. package/admin/src/containers/RBACManager/actions.js +14 -0
  276. package/admin/src/containers/RBACManager/constants.js +2 -0
  277. package/admin/src/containers/RBACManager/reducer.js +32 -0
  278. package/admin/src/containers/RBACManager/useSyncRbac.js +28 -0
  279. package/admin/src/containers/SingleTypeFormWrapper/index.js +317 -0
  280. package/admin/src/containers/SingleTypeFormWrapper/utils/getRequestUrl.js +5 -0
  281. package/admin/src/containers/SingleTypeFormWrapper/utils/index.js +2 -0
  282. package/admin/src/containers/SingleTypeRecursivePath/index.js +84 -0
  283. package/admin/src/containers/WysiwygProvider/index.js +16 -0
  284. package/admin/src/contexts/ContentTypeLayout.js +5 -0
  285. package/admin/src/contexts/LayoutDnd.js +5 -0
  286. package/admin/src/contexts/ListView.js +5 -0
  287. package/admin/src/contexts/Wysiwyg.js +5 -0
  288. package/admin/src/contexts/index.js +4 -0
  289. package/admin/src/hooks/index.js +6 -0
  290. package/admin/src/hooks/useContentTypeLayout/index.js +19 -0
  291. package/admin/src/hooks/useFetchContentTypeLayout/index.js +83 -0
  292. package/admin/src/hooks/useFetchContentTypeLayout/reducer.js +56 -0
  293. package/admin/src/hooks/useFetchContentTypeLayout/utils/formatLayouts.js +235 -0
  294. package/admin/src/hooks/useFindRedirectionLink/index.js +14 -0
  295. package/admin/src/hooks/useFindRedirectionLink/selectors.js +7 -0
  296. package/admin/src/hooks/useFindRedirectionLink/utils/getRedirectionLink.js +45 -0
  297. package/admin/src/hooks/useLayoutDnd.js +6 -0
  298. package/admin/src/hooks/useListView.js +6 -0
  299. package/admin/src/hooks/useWysiwyg.js +6 -0
  300. package/admin/src/icons/Bold/index.js +22 -0
  301. package/admin/src/icons/Code/index.js +13 -0
  302. package/admin/src/icons/Cross/index.js +33 -0
  303. package/admin/src/icons/Italic/index.js +23 -0
  304. package/admin/src/icons/Link/index.js +21 -0
  305. package/admin/src/icons/Media/index.js +14 -0
  306. package/admin/src/icons/Na/index.js +58 -0
  307. package/admin/src/icons/Ol/index.js +13 -0
  308. package/admin/src/icons/Quote/index.js +13 -0
  309. package/admin/src/icons/Striked/index.js +24 -0
  310. package/admin/src/icons/Ul/index.js +15 -0
  311. package/admin/src/icons/Underline/index.js +22 -0
  312. package/admin/src/index.js +52 -0
  313. package/admin/src/lifecycles.js +19 -0
  314. package/admin/src/permissions.js +27 -0
  315. package/admin/src/pluginId.js +5 -0
  316. package/admin/src/reducers.js +16 -0
  317. package/admin/src/selectors.js +6 -0
  318. package/admin/src/sharedReducers/crudReducer/actions.js +44 -0
  319. package/admin/src/sharedReducers/crudReducer/constants.js +7 -0
  320. package/admin/src/sharedReducers/crudReducer/reducer.js +75 -0
  321. package/admin/src/sharedReducers/crudReducer/selectors.js +5 -0
  322. package/admin/src/testUtils/data.js +305 -0
  323. package/admin/src/testUtils/index.js +4 -0
  324. package/admin/src/translations/ar.json +94 -0
  325. package/admin/src/translations/cs.json +130 -0
  326. package/admin/src/translations/de.json +177 -0
  327. package/admin/src/translations/dk.json +180 -0
  328. package/admin/src/translations/en.json +177 -0
  329. package/admin/src/translations/es.json +177 -0
  330. package/admin/src/translations/fr.json +162 -0
  331. package/admin/src/translations/id.json +175 -0
  332. package/admin/src/translations/index.js +53 -0
  333. package/admin/src/translations/it.json +177 -0
  334. package/admin/src/translations/ja.json +94 -0
  335. package/admin/src/translations/ko.json +110 -0
  336. package/admin/src/translations/ms.json +148 -0
  337. package/admin/src/translations/nl.json +94 -0
  338. package/admin/src/translations/pl.json +142 -0
  339. package/admin/src/translations/pt-BR.json +94 -0
  340. package/admin/src/translations/pt.json +94 -0
  341. package/admin/src/translations/ru.json +177 -0
  342. package/admin/src/translations/sk.json +172 -0
  343. package/admin/src/translations/th.json +155 -0
  344. package/admin/src/translations/tr.json +177 -0
  345. package/admin/src/translations/uk.json +148 -0
  346. package/admin/src/translations/vi.json +110 -0
  347. package/admin/src/translations/zh-Hans.json +177 -0
  348. package/admin/src/translations/zh.json +94 -0
  349. package/admin/src/utils/ItemTypes.js +7 -0
  350. package/admin/src/utils/checkIfAttributeIsDisplayable.js +13 -0
  351. package/admin/src/utils/createDefaultForm.js +50 -0
  352. package/admin/src/utils/dateFormats.js +18 -0
  353. package/admin/src/utils/formatFiltersFromQuery.js +55 -0
  354. package/admin/src/utils/formatFiltersToQuery.js +27 -0
  355. package/admin/src/utils/formatLayoutToApi.js +44 -0
  356. package/admin/src/utils/generatePermissionsObject.js +20 -0
  357. package/admin/src/utils/getComponents.js +50 -0
  358. package/admin/src/utils/getDisplayedValue.js +61 -0
  359. package/admin/src/utils/getFieldName.js +6 -0
  360. package/admin/src/utils/getMaxTempKey.js +12 -0
  361. package/admin/src/utils/getRequestUrl.js +5 -0
  362. package/admin/src/utils/getTrad.js +5 -0
  363. package/admin/src/utils/index.js +17 -0
  364. package/admin/src/utils/mergeMetasWithSchema.js +20 -0
  365. package/admin/src/utils/removeKeyInObject.js +45 -0
  366. package/admin/src/utils/removePasswordFieldsFromData.js +54 -0
  367. package/config/admin.json +5 -0
  368. package/config/functions/bootstrap.js +9 -0
  369. package/config/policies/has-draft-and-publish.js +19 -0
  370. package/config/policies/hasPermissions.js +34 -0
  371. package/config/policies/routing.js +27 -0
  372. package/config/routes.json +275 -0
  373. package/controllers/collection-types.js +282 -0
  374. package/controllers/components.js +66 -0
  375. package/controllers/content-types.js +112 -0
  376. package/controllers/relations.js +63 -0
  377. package/controllers/single-types.js +170 -0
  378. package/controllers/uid.js +41 -0
  379. package/controllers/validation/index.js +104 -0
  380. package/controllers/validation/model-configuration.js +114 -0
  381. package/oas.yml +757 -0
  382. package/package.json +77 -0
  383. package/services/components.js +92 -0
  384. package/services/configuration.js +79 -0
  385. package/services/content-types.js +73 -0
  386. package/services/data-mapper.js +98 -0
  387. package/services/entity-manager.js +140 -0
  388. package/services/metrics.js +34 -0
  389. package/services/permission-checker.js +69 -0
  390. package/services/permission.js +95 -0
  391. package/services/uid.js +63 -0
  392. package/services/utils/configuration/attributes.js +175 -0
  393. package/services/utils/configuration/index.js +43 -0
  394. package/services/utils/configuration/layouts.js +185 -0
  395. package/services/utils/configuration/metadatas.js +142 -0
  396. package/services/utils/configuration/settings.js +52 -0
  397. package/services/utils/store.js +93 -0
  398. package/utils/index.js +16 -0
  399. package/utils/pick-writable-attributes.js +6 -0
  400. package/utils/wrap-bad-request.js +15 -0
  401. package/validation/policies/hasPermissions.js +17 -0
@@ -0,0 +1,78 @@
1
+ import styled from 'styled-components';
2
+
3
+ /* eslint-disable */
4
+
5
+ const BannerWrapper = styled.button`
6
+ display: flex;
7
+ height: 36px;
8
+ width: 100%;
9
+ padding: 0 15px;
10
+ border-bottom: 0;
11
+ border: 1px solid rgba(227, 233, 243, 0.75);
12
+ background-color: ${({ theme }) => theme.main.colors.white};
13
+ font-size: ${({ theme }) => theme.main.sizes.fonts.md};
14
+ font-weight: ${({ theme }) => theme.main.fontWeights.semiBold};
15
+ cursor: pointer;
16
+
17
+ &:focus {
18
+ outline: 0;
19
+ }
20
+
21
+ .img-wrapper {
22
+ width: 19px;
23
+ height: 19px;
24
+ margin-right: 19px;
25
+ border-radius: 50%;
26
+ background-color: ${({ theme }) => theme.main.colors.mediumGrey};
27
+ text-align: center;
28
+ }
29
+ .label {
30
+ text-transform: capitalize;
31
+ }
32
+
33
+ svg {
34
+ path {
35
+ fill: ${({ theme }) => theme.main.colors.leftMenu['link-color']} !important;
36
+ }
37
+ }
38
+
39
+ -webkit-font-smoothing: antialiased;
40
+
41
+ > div {
42
+ align-self: center;
43
+ margin-top: -2px;
44
+ }
45
+
46
+ ${({ isFirst, theme }) => {
47
+ if (isFirst) {
48
+ return `
49
+ border-top-right-radius: ${theme.main.sizes.borderRadius};
50
+ border-top-left-radius: ${theme.main.sizes.borderRadius};
51
+ `;
52
+ }
53
+ }}
54
+
55
+ ${({ isOpen, theme }) => {
56
+ if (isOpen) {
57
+ return `
58
+ border: 1px solid ${theme.main.colors.darkBlue};
59
+ background-color: ${theme.main.colors.lightBlue};
60
+ color: ${theme.main.colors.mediumBlue};
61
+ font-weight: ${theme.main.fontWeights.bold};
62
+
63
+ .img-wrapper {
64
+ background-color: ${theme.main.colors.darkBlue};
65
+ transform: rotate(180deg);
66
+ }
67
+
68
+ svg {
69
+ path {
70
+ fill: ${theme.main.colors.mediumBlue} !important;
71
+ }
72
+ }
73
+ `;
74
+ }
75
+ }}
76
+ `;
77
+
78
+ export default BannerWrapper;
@@ -0,0 +1,33 @@
1
+ /* eslint-disable jsx-a11y/click-events-have-key-events */
2
+ import React from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import { Carret } from '@buffetjs/icons';
5
+ import Wrapper from './Wrapper';
6
+
7
+ /* eslint-disable jsx-a11y/no-static-element-interactions */
8
+
9
+ const Banner = ({ category, isOpen, onToggle, isFirst }) => {
10
+ const handleClick = () => {
11
+ onToggle(category);
12
+ };
13
+
14
+ return (
15
+ <Wrapper type="button" isFirst={isFirst} isOpen={isOpen} onClick={handleClick}>
16
+ <div className="img-wrapper">
17
+ <Carret />
18
+ </div>
19
+ <div className="label">{category}</div>
20
+ </Wrapper>
21
+ );
22
+ };
23
+
24
+ Banner.propTypes = {
25
+ category: PropTypes.string.isRequired,
26
+ isFirst: PropTypes.bool.isRequired,
27
+ isOpen: PropTypes.bool.isRequired,
28
+ onToggle: PropTypes.func.isRequired,
29
+ };
30
+
31
+ Banner.displayName = 'Banner';
32
+
33
+ export default Banner;
@@ -0,0 +1,53 @@
1
+ import React, { memo, useEffect, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { Collapse } from 'reactstrap';
4
+ import DynamicComponentCard from '../../../DynamicComponentCard';
5
+ import Banner from './Banner';
6
+
7
+ const Category = ({ category, components, isFirst, isOpen, onAddComponent, onToggle }) => {
8
+ const [showComponents, setShowComponents] = useState(false);
9
+
10
+ useEffect(() => {
11
+ if (isOpen) {
12
+ setShowComponents(true);
13
+ }
14
+ }, [isOpen]);
15
+
16
+ const handleExited = () => setShowComponents(false);
17
+
18
+ return (
19
+ <>
20
+ <Banner isFirst={isFirst} isOpen={isOpen} category={category} onToggle={onToggle} />
21
+ <Collapse isOpen={isOpen} onExited={handleExited}>
22
+ {showComponents && (
23
+ <div className="componentsList">
24
+ {components.map(({ componentUid, info: { name, icon } }) => {
25
+ return (
26
+ <DynamicComponentCard
27
+ key={componentUid}
28
+ componentUid={componentUid}
29
+ friendlyName={name}
30
+ icon={icon}
31
+ onClick={() => {
32
+ onAddComponent(componentUid);
33
+ }}
34
+ />
35
+ );
36
+ })}
37
+ </div>
38
+ )}
39
+ </Collapse>
40
+ </>
41
+ );
42
+ };
43
+
44
+ Category.propTypes = {
45
+ category: PropTypes.string.isRequired,
46
+ components: PropTypes.array.isRequired,
47
+ isFirst: PropTypes.bool.isRequired,
48
+ isOpen: PropTypes.bool.isRequired,
49
+ onAddComponent: PropTypes.func.isRequired,
50
+ onToggle: PropTypes.func.isRequired,
51
+ };
52
+
53
+ export default memo(Category);
@@ -0,0 +1,32 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Wrapper = styled.div`
4
+ overflow: hidden;
5
+
6
+ > div {
7
+ margin-top: 15px;
8
+ padding: 23px 18px 21px 18px;
9
+ background-color: #f2f3f4;
10
+ }
11
+
12
+ .componentPickerTitle {
13
+ margin-bottom: 10px;
14
+ color: #919bae;
15
+ font-weight: 600;
16
+ font-size: 13px;
17
+ line-height: normal;
18
+ }
19
+ .componentsList {
20
+ display: flex;
21
+ flex-wrap: wrap;
22
+ padding-top: 10px;
23
+ padding-left: 15px;
24
+ padding-right: 15px;
25
+ }
26
+
27
+ .categoriesList {
28
+ padding-bottom: 4px;
29
+ }
30
+ `;
31
+
32
+ export default Wrapper;
@@ -0,0 +1,88 @@
1
+ import React, { memo, useCallback, useEffect, useMemo, useState } from 'react';
2
+ import { groupBy } from 'lodash';
3
+ import PropTypes from 'prop-types';
4
+ import { Collapse } from 'reactstrap';
5
+ import { FormattedMessage } from 'react-intl';
6
+ import pluginId from '../../../pluginId';
7
+ import { useContentTypeLayout } from '../../../hooks';
8
+ import Category from './Category';
9
+ import Wrapper from './Wrapper';
10
+
11
+ const Picker = ({ components, isOpen, onClickAddComponent }) => {
12
+ const { getComponentLayout } = useContentTypeLayout();
13
+ const [categoryToOpen, setCategoryToOpen] = useState('');
14
+
15
+ const dynamicComponentCategories = useMemo(() => {
16
+ const componentsWithInfo = components.map(componentUid => {
17
+ const { category, info } = getComponentLayout(componentUid);
18
+
19
+ return { componentUid, category, info };
20
+ });
21
+
22
+ const categories = groupBy(componentsWithInfo, 'category');
23
+
24
+ return Object.keys(categories).reduce((acc, current) => {
25
+ acc.push({ category: current, components: categories[current] });
26
+
27
+ return acc;
28
+ }, []);
29
+ }, [components, getComponentLayout]);
30
+
31
+ useEffect(() => {
32
+ if (isOpen && dynamicComponentCategories.length) {
33
+ setCategoryToOpen(dynamicComponentCategories[0].category);
34
+ }
35
+ }, [isOpen, dynamicComponentCategories]);
36
+
37
+ const handleAddComponentToDz = useCallback(
38
+ componentUid => {
39
+ onClickAddComponent(componentUid);
40
+ setCategoryToOpen('');
41
+ },
42
+ [onClickAddComponent]
43
+ );
44
+
45
+ const handleClickToggle = useCallback(
46
+ categoryName => {
47
+ const nextCategoryToOpen = categoryToOpen === categoryName ? '' : categoryName;
48
+
49
+ setCategoryToOpen(nextCategoryToOpen);
50
+ },
51
+ [categoryToOpen]
52
+ );
53
+
54
+ return (
55
+ <Collapse isOpen={isOpen}>
56
+ <Wrapper>
57
+ <div>
58
+ <p className="componentPickerTitle">
59
+ <FormattedMessage id={`${pluginId}.components.DynamicZone.pick-compo`} />
60
+ </p>
61
+ <div className="categoriesList">
62
+ {dynamicComponentCategories.map(({ category, components }, index) => {
63
+ return (
64
+ <Category
65
+ key={category}
66
+ category={category}
67
+ components={components}
68
+ isOpen={category === categoryToOpen}
69
+ isFirst={index === 0}
70
+ onAddComponent={handleAddComponentToDz}
71
+ onToggle={handleClickToggle}
72
+ />
73
+ );
74
+ })}
75
+ </div>
76
+ </div>
77
+ </Wrapper>
78
+ </Collapse>
79
+ );
80
+ };
81
+
82
+ Picker.propTypes = {
83
+ components: PropTypes.array.isRequired,
84
+ isOpen: PropTypes.bool.isRequired,
85
+ onClickAddComponent: PropTypes.func.isRequired,
86
+ };
87
+
88
+ export default memo(Picker);
@@ -0,0 +1,34 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Wrapper = styled.div`
4
+ position: relative;
5
+ padding-top: 5px;
6
+ padding-bottom: 3px;
7
+ text-align: center;
8
+ .info {
9
+ position: absolute;
10
+ display: none;
11
+ top: 10px;
12
+ left: calc(50% + 28px);
13
+ > span {
14
+ letter-spacing: 0.5px;
15
+ text-transform: uppercase;
16
+ color: #007eff;
17
+ font-size: 11px;
18
+ font-weight: 700;
19
+ }
20
+ }
21
+ button {
22
+ &:not(.isOpen):hover + .info {
23
+ display: block;
24
+ }
25
+ }
26
+ .error-label {
27
+ color: #f64d0a;
28
+ font-size: 13px;
29
+ margin-top: 4px;
30
+ margin-bottom: -5px;
31
+ }
32
+ `;
33
+
34
+ export default Wrapper;
@@ -0,0 +1,238 @@
1
+ import React, { memo, useCallback, useMemo, useState } from 'react';
2
+ import { get } from 'lodash';
3
+ import isEqual from 'react-fast-compare';
4
+ import PropTypes from 'prop-types';
5
+ import { FormattedMessage, useIntl } from 'react-intl';
6
+ import { Flex } from '@buffetjs/core';
7
+ import { LabelIconWrapper, NotAllowedInput } from 'strapi-helper-plugin';
8
+ import pluginId from '../../pluginId';
9
+ import connect from './utils/connect';
10
+ import select from './utils/select';
11
+ import BaselineAlignement from './BaselineAlignement';
12
+ import Button from './Button';
13
+ import Component from './Component';
14
+ import ComponentWrapper from './ComponentWrapper';
15
+ import DynamicZoneWrapper from './DynamicZoneWrapper';
16
+ import Label from './Label';
17
+ import Wrapper from './Wrapper';
18
+ import Picker from './Picker';
19
+
20
+ /* eslint-disable react/no-array-index-key */
21
+
22
+ const DynamicZone = ({
23
+ name,
24
+ // Passed with the select function
25
+ addComponentToDynamicZone,
26
+ formErrors,
27
+ isCreatingEntry,
28
+ isFieldAllowed,
29
+ isFieldReadable,
30
+ labelIcon,
31
+ moveComponentUp,
32
+ moveComponentDown,
33
+ removeComponentFromDynamicZone,
34
+ dynamicDisplayedComponents,
35
+ fieldSchema,
36
+ metadatas,
37
+ }) => {
38
+ const [isOpen, setIsOpen] = useState(false);
39
+ const { formatMessage } = useIntl();
40
+ // We cannot use the default props here
41
+ const { max = Infinity, min = -Infinity } = fieldSchema;
42
+ const dynamicZoneErrors = useMemo(() => {
43
+ return Object.keys(formErrors)
44
+ .filter(key => {
45
+ return key === name;
46
+ })
47
+ .map(key => formErrors[key]);
48
+ }, [formErrors, name]);
49
+
50
+ const dynamicZoneAvailableComponents = useMemo(() => fieldSchema.components || [], [fieldSchema]);
51
+ const dynamicDisplayedComponentsLength = dynamicDisplayedComponents.length;
52
+ const missingComponentNumber = min - dynamicDisplayedComponentsLength;
53
+ const hasError = dynamicZoneErrors.length > 0;
54
+ const hasMinError =
55
+ dynamicZoneErrors.length > 0 && get(dynamicZoneErrors, [0, 'id'], '').includes('min');
56
+
57
+ const hasRequiredError = hasError && !hasMinError;
58
+ const hasMaxError =
59
+ hasError && get(dynamicZoneErrors, [0, 'id'], '') === 'components.Input.error.validation.max';
60
+
61
+ const handleAddComponent = useCallback(
62
+ componentUid => {
63
+ setIsOpen(false);
64
+
65
+ addComponentToDynamicZone(name, componentUid, hasError);
66
+ },
67
+ [addComponentToDynamicZone, hasError, name]
68
+ );
69
+
70
+ const handleClickOpenPicker = () => {
71
+ if (dynamicDisplayedComponentsLength < max) {
72
+ setIsOpen(prev => !prev);
73
+ } else {
74
+ strapi.notification.info(`${pluginId}.components.notification.info.maximum-requirement`);
75
+ }
76
+ };
77
+
78
+ const formattedLabelIcon = labelIcon
79
+ ? { icon: labelIcon.icon, title: formatMessage(labelIcon.title) }
80
+ : null;
81
+
82
+ if (!isFieldAllowed && isCreatingEntry) {
83
+ return (
84
+ <BaselineAlignement>
85
+ <NotAllowedInput
86
+ label={metadatas.label}
87
+ spacerHeight="5px"
88
+ labelIcon={formattedLabelIcon}
89
+ />
90
+ </BaselineAlignement>
91
+ );
92
+ }
93
+
94
+ if (!isFieldAllowed && !isFieldReadable && !isCreatingEntry) {
95
+ return (
96
+ <BaselineAlignement>
97
+ <NotAllowedInput
98
+ label={metadatas.label}
99
+ spacerHeight="5px"
100
+ labelIcon={formattedLabelIcon}
101
+ />
102
+ </BaselineAlignement>
103
+ );
104
+ }
105
+
106
+ return (
107
+ <DynamicZoneWrapper>
108
+ {dynamicDisplayedComponentsLength > 0 && (
109
+ <Label>
110
+ <Flex>
111
+ <p>
112
+ <span>{metadatas.label}</span>
113
+ </p>
114
+ {formattedLabelIcon && (
115
+ <LabelIconWrapper title={formattedLabelIcon.title}>
116
+ {formattedLabelIcon.icon}
117
+ </LabelIconWrapper>
118
+ )}
119
+ </Flex>
120
+ <p>{metadatas.description}</p>
121
+ </Label>
122
+ )}
123
+
124
+ {/* List of displayed components */}
125
+ <ComponentWrapper>
126
+ {dynamicDisplayedComponents.map((componentUid, index) => {
127
+ const showDownIcon =
128
+ isFieldAllowed &&
129
+ dynamicDisplayedComponentsLength > 0 &&
130
+ index < dynamicDisplayedComponentsLength - 1;
131
+ const showUpIcon = isFieldAllowed && dynamicDisplayedComponentsLength > 0 && index > 0;
132
+
133
+ return (
134
+ <Component
135
+ componentUid={componentUid}
136
+ key={index}
137
+ index={index}
138
+ isFieldAllowed={isFieldAllowed}
139
+ moveComponentDown={moveComponentDown}
140
+ moveComponentUp={moveComponentUp}
141
+ name={name}
142
+ removeComponentFromDynamicZone={removeComponentFromDynamicZone}
143
+ showDownIcon={showDownIcon}
144
+ showUpIcon={showUpIcon}
145
+ />
146
+ );
147
+ })}
148
+ </ComponentWrapper>
149
+ {isFieldAllowed ? (
150
+ <Wrapper>
151
+ <Button
152
+ type="button"
153
+ hasError={hasError}
154
+ className={isOpen && 'isOpen'}
155
+ onClick={handleClickOpenPicker}
156
+ />
157
+ {hasRequiredError && !isOpen && !hasMaxError && (
158
+ <div className="error-label">
159
+ <FormattedMessage id={`${pluginId}.components.DynamicZone.required`} />
160
+ </div>
161
+ )}
162
+ {hasMaxError && !isOpen && (
163
+ <div className="error-label">
164
+ <FormattedMessage id="components.Input.error.validation.max" />
165
+ </div>
166
+ )}
167
+ {hasMinError && !isOpen && (
168
+ <div className="error-label">
169
+ <FormattedMessage
170
+ id={`${pluginId}.components.DynamicZone.missing${
171
+ missingComponentNumber > 1 ? '.plural' : '.singular'
172
+ }`}
173
+ values={{ count: missingComponentNumber }}
174
+ />
175
+ </div>
176
+ )}
177
+ <div className="info">
178
+ <FormattedMessage
179
+ id={`${pluginId}.components.DynamicZone.add-compo`}
180
+ values={{ componentName: metadatas.label }}
181
+ />
182
+ </div>
183
+ <Picker
184
+ isOpen={isOpen}
185
+ components={dynamicZoneAvailableComponents}
186
+ onClickAddComponent={handleAddComponent}
187
+ />
188
+ </Wrapper>
189
+ ) : (
190
+ <BaselineAlignement top="9px" />
191
+ )}
192
+ </DynamicZoneWrapper>
193
+ );
194
+ };
195
+
196
+ DynamicZone.defaultProps = {
197
+ dynamicDisplayedComponents: [],
198
+ fieldSchema: {
199
+ max: Infinity,
200
+ min: -Infinity,
201
+ },
202
+ labelIcon: null,
203
+ };
204
+
205
+ DynamicZone.propTypes = {
206
+ addComponentToDynamicZone: PropTypes.func.isRequired,
207
+ dynamicDisplayedComponents: PropTypes.array,
208
+ fieldSchema: PropTypes.shape({
209
+ components: PropTypes.array.isRequired,
210
+ max: PropTypes.number,
211
+ min: PropTypes.number,
212
+ }),
213
+ formErrors: PropTypes.object.isRequired,
214
+ isCreatingEntry: PropTypes.bool.isRequired,
215
+ isFieldAllowed: PropTypes.bool.isRequired,
216
+ isFieldReadable: PropTypes.bool.isRequired,
217
+ labelIcon: PropTypes.shape({
218
+ icon: PropTypes.node.isRequired,
219
+ title: PropTypes.shape({
220
+ id: PropTypes.string.isRequired,
221
+ defaultMessage: PropTypes.string.isRequired,
222
+ }).isRequired,
223
+ }),
224
+ metadatas: PropTypes.shape({
225
+ description: PropTypes.string,
226
+ label: PropTypes.string,
227
+ }).isRequired,
228
+ moveComponentUp: PropTypes.func.isRequired,
229
+ moveComponentDown: PropTypes.func.isRequired,
230
+ name: PropTypes.string.isRequired,
231
+ removeComponentFromDynamicZone: PropTypes.func.isRequired,
232
+ };
233
+
234
+ const Memoized = memo(DynamicZone, isEqual);
235
+
236
+ export default connect(Memoized, select);
237
+
238
+ export { DynamicZone };
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+
3
+ function connect(WrappedComponent, select) {
4
+ return function(props) {
5
+ // eslint-disable-next-line react/prop-types
6
+ const selectors = select(props.name);
7
+
8
+ return <WrappedComponent {...props} {...selectors} />;
9
+ };
10
+ }
11
+
12
+ export default connect;
@@ -0,0 +1,49 @@
1
+ import { useMemo } from 'react';
2
+ import { get } from 'lodash';
3
+ import { useContentManagerEditViewDataManager } from 'strapi-helper-plugin';
4
+
5
+ function useSelect(name) {
6
+ const {
7
+ addComponentToDynamicZone,
8
+ createActionAllowedFields,
9
+ isCreatingEntry,
10
+ formErrors,
11
+ modifiedData,
12
+ moveComponentUp,
13
+ moveComponentDown,
14
+ removeComponentFromDynamicZone,
15
+ readActionAllowedFields,
16
+ updateActionAllowedFields,
17
+ } = useContentManagerEditViewDataManager();
18
+
19
+ const dynamicDisplayedComponents = useMemo(
20
+ () => get(modifiedData, [name], []).map(data => data.__component),
21
+ [modifiedData, name]
22
+ );
23
+
24
+ const isFieldAllowed = useMemo(() => {
25
+ const allowedFields = isCreatingEntry ? createActionAllowedFields : updateActionAllowedFields;
26
+
27
+ return allowedFields.includes(name);
28
+ }, [name, isCreatingEntry, createActionAllowedFields, updateActionAllowedFields]);
29
+
30
+ const isFieldReadable = useMemo(() => {
31
+ const allowedFields = isCreatingEntry ? [] : readActionAllowedFields;
32
+
33
+ return allowedFields.includes(name);
34
+ }, [name, isCreatingEntry, readActionAllowedFields]);
35
+
36
+ return {
37
+ addComponentToDynamicZone,
38
+ formErrors,
39
+ isCreatingEntry,
40
+ isFieldAllowed,
41
+ isFieldReadable,
42
+ moveComponentUp,
43
+ moveComponentDown,
44
+ removeComponentFromDynamicZone,
45
+ dynamicDisplayedComponents,
46
+ };
47
+ }
48
+
49
+ export default useSelect;
@@ -0,0 +1,44 @@
1
+ import styled from 'styled-components';
2
+
3
+ const ComponentIcon = styled.div`
4
+ position: absolute;
5
+ top: -16px;
6
+ left: 10px;
7
+ display: flex;
8
+
9
+ > .component_name {
10
+ overflow: hidden;
11
+ position: relative;
12
+ width: auto;
13
+ height: 31px;
14
+ padding: 0 11px 0 39px;
15
+ color: #007eff;
16
+ font-size: 13px;
17
+ font-weight: 600;
18
+ line-height: 26px;
19
+ border-radius: 31px;
20
+ border: 2px solid white;
21
+ background-color: #e6f0fb;
22
+
23
+ .component_icon {
24
+ z-index: 1;
25
+ display: flex;
26
+ position: absolute;
27
+ top: -1px;
28
+ left: -1px;
29
+ width: 29px;
30
+ height: 29px;
31
+ border-radius: 31px;
32
+ border: 1px solid white;
33
+ background-color: #e6f0fb;
34
+
35
+ svg {
36
+ margin: auto;
37
+ color: #007eff;
38
+ font-size: 11px;
39
+ }
40
+ }
41
+ }
42
+ `;
43
+
44
+ export default ComponentIcon;
@@ -0,0 +1,19 @@
1
+ import styled from 'styled-components';
2
+
3
+ const EmptyComponent = styled.div`
4
+ height: 72px;
5
+ border: 1px solid rgba(227, 233, 243, 0.75);
6
+ border-top-left-radius: 2px;
7
+ border-top-right-radius: 2px;
8
+ border-bottom: 0;
9
+ line-height: 73px;
10
+ text-align: center;
11
+
12
+ > p {
13
+ color: #9ea7b8;
14
+ font-size: 13px;
15
+ font-weight: 500;
16
+ }
17
+ `;
18
+
19
+ export default EmptyComponent;
@@ -0,0 +1,10 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Label = styled.label`
4
+ font-weight: 500;
5
+ font-size: 13px;
6
+ margin-bottom: 1rem;
7
+ display: block;
8
+ `;
9
+
10
+ export default Label;