@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,70 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { useHistory } from 'react-router-dom';
3
+ import PropTypes from 'prop-types';
4
+ import { hasPermissions, useUser } from 'strapi-helper-plugin';
5
+ import pluginId from '../../pluginId';
6
+ import pluginPermissions from '../../permissions';
7
+ import DynamicComponentCard from '../DynamicComponentCard';
8
+ import Tooltip from './Tooltip';
9
+
10
+ const DynamicComponent = ({ componentUid, friendlyName, icon, setIsOverDynamicZone }) => {
11
+ const [isOver, setIsOver] = useState(false);
12
+ const [{ isLoading, canAccess }, setState] = useState({ isLoading: true, canAccess: false });
13
+ const { push } = useHistory();
14
+ const { userPermissions } = useUser();
15
+
16
+ useEffect(() => {
17
+ const checkPermission = async () => {
18
+ try {
19
+ const canAccess = await hasPermissions(
20
+ userPermissions,
21
+ pluginPermissions.componentsConfigurations
22
+ );
23
+
24
+ setState({ isLoading: false, canAccess });
25
+ } catch (err) {
26
+ setState({ isLoading: false });
27
+ }
28
+ };
29
+
30
+ checkPermission();
31
+ // eslint-disable-next-line react-hooks/exhaustive-deps
32
+ }, []);
33
+
34
+ const handleMouseEvent = () => {
35
+ setIsOverDynamicZone(v => !v);
36
+ setIsOver(v => !v);
37
+ };
38
+
39
+ return (
40
+ <DynamicComponentCard
41
+ componentUid={componentUid}
42
+ friendlyName={friendlyName}
43
+ icon={icon}
44
+ isOver={isOver}
45
+ onClick={() => {
46
+ if (!isLoading && canAccess) {
47
+ push(`/plugins/${pluginId}/components/${componentUid}/configurations/edit`);
48
+ }
49
+ }}
50
+ onMouseEvent={handleMouseEvent}
51
+ tradId="components.DraggableAttr.edit"
52
+ >
53
+ <Tooltip isOver={isOver}>{componentUid}</Tooltip>
54
+ </DynamicComponentCard>
55
+ );
56
+ };
57
+
58
+ DynamicComponent.defaultProps = {
59
+ friendlyName: '',
60
+ icon: 'smile',
61
+ };
62
+
63
+ DynamicComponent.propTypes = {
64
+ componentUid: PropTypes.string.isRequired,
65
+ friendlyName: PropTypes.string,
66
+ icon: PropTypes.string,
67
+ setIsOverDynamicZone: PropTypes.func.isRequired,
68
+ };
69
+
70
+ export default DynamicComponent;
@@ -0,0 +1,10 @@
1
+ import styled from 'styled-components';
2
+
3
+ const DynamicZoneWrapper = styled.div`
4
+ display: flex;
5
+ margin: 5px 0 0px 0;
6
+ overflow: auto;
7
+ height: 119px;
8
+ `;
9
+
10
+ export default DynamicZoneWrapper;
@@ -0,0 +1,19 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Tooltip = styled.div`
4
+ position: absolute;
5
+ bottom: -10px;
6
+ left: 105px;
7
+ visibility: ${({ isOver }) => (isOver ? 'visible' : 'hidden')};
8
+ line-height: 20px;
9
+ height: 20px;
10
+ padding: 0 10px;
11
+ background-color: #000000;
12
+ font-size: 12px;
13
+ color: #fff;
14
+ opacity: 0.5;
15
+ border: 1px solid #e3e9f3;
16
+ z-index: 99;
17
+ `;
18
+
19
+ export default Tooltip;
@@ -0,0 +1,24 @@
1
+ import styled from 'styled-components';
2
+ import PropTypes from 'prop-types';
3
+
4
+ const Wrapper = styled.div`
5
+ display: flex;
6
+ position: relative;
7
+ min-height: ${({ withLongerHeight }) =>
8
+ withLongerHeight ? '102px' : '30px'};
9
+
10
+ .sub {
11
+ width: 100%;
12
+ padding: 0 5px;
13
+ }
14
+ `;
15
+
16
+ Wrapper.defaultProps = {
17
+ withLongerHeight: false,
18
+ };
19
+
20
+ Wrapper.propTypes = {
21
+ withLongerHeight: PropTypes.bool,
22
+ };
23
+
24
+ export default Wrapper;
@@ -0,0 +1,194 @@
1
+ import React, { forwardRef, useState } from 'react';
2
+ import { get } from 'lodash';
3
+ import PropTypes from 'prop-types';
4
+ import DraggedField from '../DraggedField';
5
+ import PreviewCarret from '../PreviewCarret';
6
+ import Carret from './Carret';
7
+ import DynamicZoneWrapper from './DynamicZoneWrapper';
8
+ import Wrapper from './Wrapper';
9
+ import DynamicComponent from './DynamicComponent';
10
+
11
+ /* eslint-disable react/no-array-index-key */
12
+
13
+ const DraggedFieldWithPreview = forwardRef(
14
+ (
15
+ {
16
+ goTo,
17
+ componentUid,
18
+ componentLayouts,
19
+ dynamicZoneComponents,
20
+ isDragging,
21
+ label,
22
+ name,
23
+ onClickEdit,
24
+ onClickRemove,
25
+ selectedItem,
26
+ showLeftCarret,
27
+ showRightCarret,
28
+ size,
29
+ style,
30
+ type,
31
+ },
32
+ refs
33
+ ) => {
34
+ const isHidden = name === '_TEMP_';
35
+ const [dragStart, setDragStart] = useState(false);
36
+ const [isOverDynamicZone, setIsOverDynamicZone] = useState(false);
37
+ const opacity = isDragging ? 0.2 : 1;
38
+ const isFullSize = size === 12;
39
+ const display = isFullSize && dragStart ? 'none' : '';
40
+ const width = isFullSize && dragStart ? 0 : '100%';
41
+ const higherFields = ['json', 'text', 'file', 'media', 'component', 'richtext', 'dynamiczone'];
42
+ const withLongerHeight = higherFields.includes(type) && !dragStart;
43
+ const getCompoInfos = uid => get(componentLayouts, [uid, 'info'], { name: '', icon: '' });
44
+
45
+ const componentData = get(componentLayouts, [componentUid], {});
46
+ const componentLayout = get(componentData, ['layouts', 'edit'], []);
47
+ const getWrapperWitdh = colNum => `${(1 / 12) * colNum * 100}%`;
48
+
49
+ return (
50
+ <div
51
+ style={{ width: getWrapperWitdh(size) }}
52
+ onDrag={() => {
53
+ if (isFullSize && !dragStart) {
54
+ setDragStart(true);
55
+ }
56
+ }}
57
+ onDragEnd={() => {
58
+ if (isFullSize) {
59
+ setDragStart(false);
60
+ }
61
+ }}
62
+ >
63
+ <Wrapper ref={refs.dropRef} withLongerHeight={withLongerHeight} style={style}>
64
+ {dragStart && isFullSize && <PreviewCarret style={{ marginRight: '-10px' }} />}
65
+ <>
66
+ {showLeftCarret && <Carret />}
67
+
68
+ <div className="sub" style={{ width, opacity }}>
69
+ <DraggedField
70
+ goTo={goTo}
71
+ componentUid={componentUid}
72
+ isHidden={isHidden}
73
+ isOverDynamicZone={isOverDynamicZone}
74
+ label={label}
75
+ name={name}
76
+ onClick={onClickEdit}
77
+ onRemove={onClickRemove}
78
+ ref={refs.dragRef}
79
+ selectedItem={selectedItem}
80
+ style={{ display, marginRight: 0, paddingRight: 0 }}
81
+ type={type}
82
+ withLongerHeight={withLongerHeight}
83
+ >
84
+ {type === 'component' &&
85
+ componentLayout.map((row, i) => {
86
+ const marginBottom = i === componentLayout.length - 1 ? '29px' : '';
87
+ const marginTop = i === 0 ? '5px' : '';
88
+
89
+ return (
90
+ <div
91
+ style={{
92
+ display: 'flex',
93
+ marginBottom,
94
+ marginTop,
95
+ }}
96
+ key={i}
97
+ >
98
+ {row.map(field => {
99
+ const fieldType = get(
100
+ componentData,
101
+ ['attributes', field.name, 'type'],
102
+ ''
103
+ );
104
+ const label = get(
105
+ componentData,
106
+ ['metadatas', field.name, 'edit', 'label'],
107
+ ''
108
+ );
109
+
110
+ return (
111
+ <div
112
+ key={field.name}
113
+ style={{
114
+ width: getWrapperWitdh(field.size),
115
+ marginBottom: '6px',
116
+ }}
117
+ >
118
+ <DraggedField
119
+ label={label}
120
+ name={field.name}
121
+ isSub
122
+ withLongerHeight={higherFields.includes(fieldType)}
123
+ />
124
+ </div>
125
+ );
126
+ })}
127
+ </div>
128
+ );
129
+ })}
130
+ {type === 'dynamiczone' && (
131
+ <DynamicZoneWrapper>
132
+ {dynamicZoneComponents.map(compo => {
133
+ const { name, icon } = getCompoInfos(compo);
134
+
135
+ return (
136
+ <DynamicComponent
137
+ key={compo}
138
+ componentUid={compo}
139
+ friendlyName={name}
140
+ icon={icon}
141
+ setIsOverDynamicZone={setIsOverDynamicZone}
142
+ />
143
+ );
144
+ })}
145
+ </DynamicZoneWrapper>
146
+ )}
147
+ </DraggedField>
148
+ </div>
149
+ {showRightCarret && <Carret right />}
150
+ </>
151
+ </Wrapper>
152
+ </div>
153
+ );
154
+ }
155
+ );
156
+
157
+ DraggedFieldWithPreview.defaultProps = {
158
+ goTo: () => {},
159
+ componentLayouts: {},
160
+ componentUid: null,
161
+ dynamicZoneComponents: [],
162
+ isDragging: false,
163
+ label: '',
164
+ onClickEdit: () => {},
165
+ onClickRemove: () => {},
166
+ selectedItem: '',
167
+ showLeftCarret: false,
168
+ showRightCarret: false,
169
+ size: 1,
170
+ style: {},
171
+ type: 'string',
172
+ };
173
+
174
+ DraggedFieldWithPreview.propTypes = {
175
+ goTo: PropTypes.func,
176
+ componentLayouts: PropTypes.object,
177
+ componentUid: PropTypes.string,
178
+ dynamicZoneComponents: PropTypes.array,
179
+ isDragging: PropTypes.bool,
180
+ label: PropTypes.string,
181
+ name: PropTypes.string.isRequired,
182
+ onClickEdit: PropTypes.func,
183
+ onClickRemove: PropTypes.func,
184
+ selectedItem: PropTypes.string,
185
+ showLeftCarret: PropTypes.bool,
186
+ showRightCarret: PropTypes.bool,
187
+ size: PropTypes.number,
188
+ style: PropTypes.object,
189
+ type: PropTypes.string,
190
+ };
191
+
192
+ DraggedFieldWithPreview.displayName = 'DraggedFieldWithPreview';
193
+
194
+ export default DraggedFieldWithPreview;
@@ -0,0 +1,63 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Wrapper = styled.div`
4
+ position: relative;
5
+ height: 90px;
6
+ width: 139px !important;
7
+ margin: 0 10px 10px 0;
8
+ padding: 18px 10px;
9
+ background-color: #ffffff;
10
+ color: #919bae;
11
+ text-align: center;
12
+ border-radius: 2px;
13
+ cursor: pointer;
14
+ border: 1px solid #ffffff;
15
+
16
+ button {
17
+ outline: 0;
18
+ }
19
+
20
+ .component-uid {
21
+ width: 119px;
22
+ text-overflow: ellipsis;
23
+ overflow: hidden;
24
+ white-space: nowrap;
25
+ color: #919bae;
26
+ font-weight: 500;
27
+ font-size: 13px;
28
+ line-height: normal;
29
+ }
30
+
31
+ .component-icon {
32
+ width: 35px;
33
+ height: 35px;
34
+ margin-bottom: 5px;
35
+ line-height: 35px;
36
+ align-self: center;
37
+ border-radius: 50%;
38
+ background-color: #e9eaeb;
39
+ color: #b4b6ba;
40
+ padding: 0;
41
+ i,
42
+ svg {
43
+ margin: auto;
44
+ display: block;
45
+ }
46
+ }
47
+
48
+ &:hover {
49
+ background-color: #e6f0fb;
50
+ color: #007eff;
51
+ border: 1px solid #aed4fb;
52
+
53
+ .component-icon {
54
+ background-color: #aed4fb;
55
+ color: #007eff;
56
+ }
57
+ .component-uid {
58
+ color: #007eff;
59
+ }
60
+ }
61
+ `;
62
+
63
+ export default Wrapper;
@@ -0,0 +1,49 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
4
+ import Wrapper from './Wrapper';
5
+
6
+ const DynamicComponentCard = ({
7
+ children,
8
+ componentUid,
9
+ friendlyName,
10
+ icon,
11
+ onClick,
12
+ }) => {
13
+ return (
14
+ <Wrapper
15
+ onClick={e => {
16
+ e.preventDefault();
17
+ e.stopPropagation();
18
+
19
+ onClick(componentUid);
20
+ }}
21
+ >
22
+ <button className="component-icon" type="button">
23
+ <FontAwesomeIcon icon={icon} />
24
+ </button>
25
+
26
+ <div className="component-uid">
27
+ <span>{friendlyName}</span>
28
+ </div>
29
+ {children}
30
+ </Wrapper>
31
+ );
32
+ };
33
+
34
+ DynamicComponentCard.defaultProps = {
35
+ children: null,
36
+ friendlyName: '',
37
+ onClick: () => {},
38
+ icon: 'smile',
39
+ };
40
+
41
+ DynamicComponentCard.propTypes = {
42
+ children: PropTypes.node,
43
+ componentUid: PropTypes.string.isRequired,
44
+ friendlyName: PropTypes.string,
45
+ icon: PropTypes.string,
46
+ onClick: PropTypes.func,
47
+ };
48
+
49
+ export default DynamicComponentCard;
@@ -0,0 +1,11 @@
1
+ import styled from 'styled-components';
2
+
3
+ const BaselineAlignement = styled.div`
4
+ padding-top: ${({ top }) => top};
5
+ `;
6
+
7
+ BaselineAlignement.defaultProps = {
8
+ top: '1px',
9
+ };
10
+
11
+ export default BaselineAlignement;
@@ -0,0 +1,31 @@
1
+ import styled from 'styled-components';
2
+ import PlusButton from '../PlusButton';
3
+
4
+ /* eslint-disable indent */
5
+ const Button = styled(PlusButton)`
6
+ transform: rotate(-90deg);
7
+ transition: background-color 0.1s linear;
8
+ transition: transform 0.1s ease-in-out;
9
+ &:hover {
10
+ background-color: #aed4fb;
11
+ :before,
12
+ :after {
13
+ background-color: #007eff;
14
+ }
15
+ }
16
+
17
+ ${({ hasError }) =>
18
+ hasError &&
19
+ `
20
+ background-color: #FAA684;
21
+ :before, :after {
22
+ background-color: #F64D0A;
23
+ }
24
+ `}
25
+
26
+ &.isOpen {
27
+ transform: rotate(-45deg);
28
+ }
29
+ `;
30
+
31
+ export default Button;
@@ -0,0 +1,45 @@
1
+ import styled from 'styled-components';
2
+
3
+ const RoundCTA = styled.div`
4
+ height: 31px;
5
+ width: 31px;
6
+ border-radius: 50%;
7
+ background-color: #f2f3f4;
8
+ border: 2px solid #ffffff;
9
+ cursor: pointer;
10
+ display: flex;
11
+ z-index: 9;
12
+ svg {
13
+ font-size: 10px;
14
+ line-height: 29px;
15
+ margin: auto;
16
+ }
17
+ &:not(.arrow-btn) {
18
+ position: absolute;
19
+ top: -16px;
20
+ right: 10px;
21
+ transition: all 200ms ease-in;
22
+ &:hover {
23
+ background-color: #faa684;
24
+ color: #f64d0a;
25
+ }
26
+ }
27
+ &.arrow-btn {
28
+ height: 22px;
29
+ width: 22px;
30
+ background-color: #ffffff;
31
+ border: 2px solid #ffffff;
32
+ svg {
33
+ font-size: 10px;
34
+ line-height: 22px;
35
+ }
36
+ &:hover {
37
+ background-color: #f2f3f4;
38
+ }
39
+ &.arrow-down {
40
+ transform: rotate(180deg);
41
+ }
42
+ }
43
+ `;
44
+
45
+ export default RoundCTA;
@@ -0,0 +1,79 @@
1
+ import React, { memo, useMemo } from 'react';
2
+ import { Arrow } from '@buffetjs/icons';
3
+ import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
4
+ import PropTypes from 'prop-types';
5
+ import isEqual from 'react-fast-compare';
6
+ import { useContentTypeLayout } from '../../../hooks';
7
+ import FieldComponent from '../../FieldComponent';
8
+ import RoundCTA from './RoundCTA';
9
+
10
+ const Component = ({
11
+ componentUid,
12
+ index,
13
+ isFieldAllowed,
14
+ moveComponentDown,
15
+ moveComponentUp,
16
+ name,
17
+ removeComponentFromDynamicZone,
18
+ showDownIcon,
19
+ showUpIcon,
20
+ }) => {
21
+ const { getComponentLayout } = useContentTypeLayout();
22
+ const { icon, friendlyName } = useMemo(() => {
23
+ const {
24
+ info: { icon, name },
25
+ } = getComponentLayout(componentUid);
26
+
27
+ return { friendlyName: name, icon };
28
+ }, [componentUid, getComponentLayout]);
29
+
30
+ const handleMoveComponentDown = () => moveComponentDown(name, index);
31
+
32
+ const handleMoveComponentUp = () => moveComponentUp(name, index);
33
+
34
+ const handleRemove = () => removeComponentFromDynamicZone(name, index);
35
+
36
+ return (
37
+ <div>
38
+ <div className="arrow-icons">
39
+ {showDownIcon && (
40
+ <RoundCTA className="arrow-btn arrow-down" onClick={handleMoveComponentDown}>
41
+ <Arrow />
42
+ </RoundCTA>
43
+ )}
44
+ {showUpIcon && (
45
+ <RoundCTA className="arrow-btn arrow-up" onClick={handleMoveComponentUp}>
46
+ <Arrow />
47
+ </RoundCTA>
48
+ )}
49
+ </div>
50
+ {isFieldAllowed && (
51
+ <RoundCTA onClick={handleRemove}>
52
+ <FontAwesomeIcon icon="trash-alt" />
53
+ </RoundCTA>
54
+ )}
55
+ <FieldComponent
56
+ componentUid={componentUid}
57
+ componentFriendlyName={friendlyName}
58
+ icon={icon}
59
+ label=""
60
+ name={`${name}.${index}`}
61
+ isFromDynamicZone
62
+ />
63
+ </div>
64
+ );
65
+ };
66
+
67
+ Component.propTypes = {
68
+ componentUid: PropTypes.string.isRequired,
69
+ index: PropTypes.number.isRequired,
70
+ isFieldAllowed: PropTypes.bool.isRequired,
71
+ moveComponentDown: PropTypes.func.isRequired,
72
+ moveComponentUp: PropTypes.func.isRequired,
73
+ name: PropTypes.string.isRequired,
74
+ removeComponentFromDynamicZone: PropTypes.func.isRequired,
75
+ showDownIcon: PropTypes.bool.isRequired,
76
+ showUpIcon: PropTypes.bool.isRequired,
77
+ };
78
+
79
+ export default memo(Component, isEqual);
@@ -0,0 +1,44 @@
1
+ import styled from 'styled-components';
2
+
3
+ const ComponentWrapper = styled.div`
4
+ position: relative;
5
+ > div {
6
+ position: relative;
7
+ box-shadow: 0 2px 4px #e3e9f3;
8
+ border-radius: 2px;
9
+ .arrow-icons {
10
+ position: absolute;
11
+ top: -12px;
12
+ right: 49px;
13
+ z-index: 9;
14
+ .arrow-btn {
15
+ display: inline-flex;
16
+ svg {
17
+ margin-left: 5px;
18
+ margin-top: 5px;
19
+ }
20
+ }
21
+ }
22
+ &:not(:first-of-type) {
23
+ margin-top: 32px;
24
+ &:before {
25
+ content: '&';
26
+ position: absolute;
27
+ top: -30px;
28
+ left: 24.5px;
29
+ height: 100%;
30
+ width: 2px;
31
+ background-color: #e6f0fb;
32
+ color: transparent;
33
+ }
34
+ }
35
+ > div:last-of-type {
36
+ padding-top: 6px;
37
+ padding-bottom: 5px;
38
+ margin-bottom: 22px;
39
+ border-radius: 2px;
40
+ }
41
+ }
42
+ `;
43
+
44
+ export default ComponentWrapper;
@@ -0,0 +1,12 @@
1
+ import styled from 'styled-components';
2
+
3
+ const DynamicZoneWrapper = styled.div`
4
+ position: relative;
5
+ padding-top: 10px;
6
+ margin-bottom: 15px;
7
+ & + & {
8
+ padding-top: 13px;
9
+ }
10
+ `;
11
+
12
+ export default DynamicZoneWrapper;
@@ -0,0 +1,42 @@
1
+ import styled from 'styled-components';
2
+
3
+ const Label = styled.div`
4
+ padding: 9px 20px;
5
+ font-size: 13px;
6
+ font-weight: 600;
7
+ position: relative;
8
+ min-height: 64px;
9
+ &:after {
10
+ content: '•';
11
+ position: absolute;
12
+ top: 15px;
13
+ left: 21.5px;
14
+ font-size: 15px;
15
+ width: 8px;
16
+ height: 8px;
17
+ background-color: #aed4fb;
18
+ color: transparent;
19
+ border-radius: 4px;
20
+ border: 1px solid white;
21
+ }
22
+ &:before {
23
+ content: '&';
24
+ position: absolute;
25
+ top: 22px;
26
+ left: 24.5px;
27
+ height: 100%;
28
+ width: 2px;
29
+ background-color: #e6f0fb;
30
+ color: transparent;
31
+ }
32
+ p {
33
+ padding-left: 18px;
34
+ margin-bottom: 0;
35
+ }
36
+ p:last-of-type:not(:first-of-type) {
37
+ color: #9ea7b8;
38
+ font-weight: 400;
39
+ }
40
+ `;
41
+
42
+ export default Label;