@webiny/app-admin 0.0.0-mt-1

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 (357) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +21 -0
  3. package/assets/icons/add-18px.svg +3 -0
  4. package/assets/icons/arrow_drop_down-24px.svg +4 -0
  5. package/assets/icons/attach_file_black_24dp.svg +1 -0
  6. package/assets/icons/baseline-menu-24px.svg +4 -0
  7. package/assets/icons/baseline-notification_important-24px.svg +4 -0
  8. package/assets/icons/baseline-security-24px.svg +4 -0
  9. package/assets/icons/filter-24px.svg +8 -0
  10. package/assets/icons/github-brands.svg +1 -0
  11. package/assets/icons/highlight-24px.svg +1 -0
  12. package/assets/icons/icon-community.svg +16 -0
  13. package/assets/icons/icon-documentation.svg +16 -0
  14. package/assets/icons/info.svg +1 -0
  15. package/assets/icons/insert_drive_file-24px.svg +1 -0
  16. package/assets/icons/insert_photo-24px.svg +1 -0
  17. package/assets/icons/label-24px.svg +1 -0
  18. package/assets/icons/round-account_circle-24px.svg +1 -0
  19. package/assets/icons/round-add-24px.svg +16 -0
  20. package/assets/icons/round-arrow_drop_down-24px.svg +1 -0
  21. package/assets/icons/round-chevron_right-24px.svg +12 -0
  22. package/assets/icons/round-feedback-24px.svg +54 -0
  23. package/assets/icons/round-help-24px.svg +1 -0
  24. package/assets/icons/round-invert_colors-24px.svg +52 -0
  25. package/assets/icons/round-keyboard_arrow_down-24px.svg +16 -0
  26. package/assets/icons/round-keyboard_arrow_up-24px.svg +16 -0
  27. package/assets/icons/round-lock_open-24px.svg +60 -0
  28. package/assets/icons/round-more_vert-24px.svg +12 -0
  29. package/assets/icons/round-open_in_new-24px.svg +44 -0
  30. package/assets/icons/round-settings-24px.svg +4 -0
  31. package/assets/icons/search-24px.svg +20 -0
  32. package/assets/icons/slack-logo.svg +1 -0
  33. package/assets/icons/today-24px.svg +1 -0
  34. package/assets/icons/touch_app.svg +1 -0
  35. package/assets/images/arr.png +0 -0
  36. package/assets/images/arr_2.png +0 -0
  37. package/assets/images/header_bg.jpg +0 -0
  38. package/assets/images/icons.png +0 -0
  39. package/assets/images/icons_retina.png +0 -0
  40. package/assets/images/logo.png +0 -0
  41. package/assets/images/logo_orange.png +0 -0
  42. package/assets/images/public/bg-login.png +0 -0
  43. package/assets/images/public/favicon.ico +0 -0
  44. package/assets/images/public/logo_orange.png +0 -0
  45. package/assets/images/public/preloader_2.png +0 -0
  46. package/assets/images/swich.png +0 -0
  47. package/assets/images/table_img.jpg +0 -0
  48. package/assets/images/webiny-logo.svg +20 -0
  49. package/assets/images/webiny-orange-logo.svg +20 -0
  50. package/components/AdminLayout.d.ts +7 -0
  51. package/components/AdminLayout.js +35 -0
  52. package/components/AppInstaller/Sidebar.d.ts +7 -0
  53. package/components/AppInstaller/Sidebar.js +158 -0
  54. package/components/AppInstaller/assets/sign-in-divider.svg +19 -0
  55. package/components/AppInstaller/index.d.ts +5 -0
  56. package/components/AppInstaller/index.js +134 -0
  57. package/components/AppInstaller/styled.d.ts +7 -0
  58. package/components/AppInstaller/styled.js +73 -0
  59. package/components/AppInstaller/useInstaller.d.ts +11 -0
  60. package/components/AppInstaller/useInstaller.js +279 -0
  61. package/components/EmptyView.d.ts +8 -0
  62. package/components/EmptyView.js +56 -0
  63. package/components/FileManager/BottomInfoBar/SupportedFileTypes.d.ts +5 -0
  64. package/components/FileManager/BottomInfoBar/SupportedFileTypes.js +35 -0
  65. package/components/FileManager/BottomInfoBar/UploadStatus.d.ts +5 -0
  66. package/components/FileManager/BottomInfoBar/UploadStatus.js +47 -0
  67. package/components/FileManager/BottomInfoBar.d.ts +3 -0
  68. package/components/FileManager/BottomInfoBar.js +42 -0
  69. package/components/FileManager/DropFilesHere.d.ts +8 -0
  70. package/components/FileManager/DropFilesHere.js +58 -0
  71. package/components/FileManager/File.d.ts +18 -0
  72. package/components/FileManager/File.js +129 -0
  73. package/components/FileManager/FileDetails/Name.d.ts +6 -0
  74. package/components/FileManager/FileDetails/Name.js +113 -0
  75. package/components/FileManager/FileDetails/Tags.d.ts +6 -0
  76. package/components/FileManager/FileDetails/Tags.js +241 -0
  77. package/components/FileManager/FileDetails.d.ts +23 -0
  78. package/components/FileManager/FileDetails.js +392 -0
  79. package/components/FileManager/FileManagerContext.d.ts +23 -0
  80. package/components/FileManager/FileManagerContext.js +174 -0
  81. package/components/FileManager/FileManagerView.d.ts +23 -0
  82. package/components/FileManager/FileManagerView.js +632 -0
  83. package/components/FileManager/LeftSidebar.d.ts +8 -0
  84. package/components/FileManager/LeftSidebar.js +95 -0
  85. package/components/FileManager/NoPermissionView.d.ts +3 -0
  86. package/components/FileManager/NoPermissionView.js +70 -0
  87. package/components/FileManager/NoResults.d.ts +2 -0
  88. package/components/FileManager/NoResults.js +13 -0
  89. package/components/FileManager/getFileTypePlugin.d.ts +1 -0
  90. package/components/FileManager/getFileTypePlugin.js +27 -0
  91. package/components/FileManager/getFileUploader.d.ts +2 -0
  92. package/components/FileManager/getFileUploader.js +10 -0
  93. package/components/FileManager/graphql.d.ts +6 -0
  94. package/components/FileManager/graphql.js +17 -0
  95. package/components/FileManager/icons/content_copy-black-24px.svg +1 -0
  96. package/components/FileManager/icons/delete.svg +12 -0
  97. package/components/FileManager/icons/privacy_tip-24px.svg +10 -0
  98. package/components/FileManager/icons/round-check_box-24px.svg +4 -0
  99. package/components/FileManager/icons/round-check_box_outline_blank-24px.svg +4 -0
  100. package/components/FileManager/icons/round-cloud_download-24px.svg +4 -0
  101. package/components/FileManager/icons/round-cloud_upload-24px.svg +4 -0
  102. package/components/FileManager/icons/round-description-24px.svg +4 -0
  103. package/components/FileManager/icons/round-edit-24px.svg +4 -0
  104. package/components/FileManager/icons/round-info-24px.svg +4 -0
  105. package/components/FileManager/icons/round-label-24px.svg +4 -0
  106. package/components/FileManager/icons/round-more_vert-24px.svg +4 -0
  107. package/components/FileManager/icons/round-search-24px.svg +20 -0
  108. package/components/FileManager/outputFileSelectionError.d.ts +2 -0
  109. package/components/FileManager/outputFileSelectionError.js +39 -0
  110. package/components/FileManager.d.ts +18 -0
  111. package/components/FileManager.js +133 -0
  112. package/components/FloatingActionButton.d.ts +3 -0
  113. package/components/FloatingActionButton.js +17 -0
  114. package/components/MultiImageUpload.d.ts +4 -0
  115. package/components/MultiImageUpload.js +20 -0
  116. package/components/OverlayLayout/OverlayLayout.d.ts +25 -0
  117. package/components/OverlayLayout/OverlayLayout.js +159 -0
  118. package/components/OverlayLayout/icons/close.svg +13 -0
  119. package/components/OverlayLayout/icons/navigate_before.svg +16 -0
  120. package/components/OverlayLayout/index.d.ts +1 -0
  121. package/components/OverlayLayout/index.js +1 -0
  122. package/components/Permissions/Permissions.d.ts +7 -0
  123. package/components/Permissions/Permissions.js +37 -0
  124. package/components/Permissions/StyledComponents.d.ts +6 -0
  125. package/components/Permissions/StyledComponents.js +19 -0
  126. package/components/Permissions/index.d.ts +2 -0
  127. package/components/Permissions/index.js +2 -0
  128. package/components/RichTextEditor/RichTextEditor.d.ts +3 -0
  129. package/components/RichTextEditor/RichTextEditor.js +15 -0
  130. package/components/RichTextEditor/index.d.ts +2 -0
  131. package/components/RichTextEditor/index.js +2 -0
  132. package/components/RichTextEditor/styles.scss +64 -0
  133. package/components/RichTextEditor/tools/header/index.d.ts +228 -0
  134. package/components/RichTextEditor/tools/header/index.js +731 -0
  135. package/components/RichTextEditor/tools/header/styles.scss +48 -0
  136. package/components/RichTextEditor/tools/image/index.d.ts +97 -0
  137. package/components/RichTextEditor/tools/image/index.js +257 -0
  138. package/components/RichTextEditor/tools/image/styles.scss +90 -0
  139. package/components/RichTextEditor/tools/image/svgs.d.ts +6 -0
  140. package/components/RichTextEditor/tools/image/svgs.js +5 -0
  141. package/components/RichTextEditor/tools/image/tunes.d.ts +58 -0
  142. package/components/RichTextEditor/tools/image/tunes.js +134 -0
  143. package/components/RichTextEditor/tools/image/ui.d.ts +111 -0
  144. package/components/RichTextEditor/tools/image/ui.js +281 -0
  145. package/components/RichTextEditor/tools/paragraph/index.d.ts +211 -0
  146. package/components/RichTextEditor/tools/paragraph/index.js +520 -0
  147. package/components/RichTextEditor/tools/paragraph/styles.scss +29 -0
  148. package/components/RichTextEditor/tools/textColor/index.d.ts +58 -0
  149. package/components/RichTextEditor/tools/textColor/index.js +232 -0
  150. package/components/RichTextEditor/tools/textColor/styles.scss +21 -0
  151. package/components/RichTextEditor/tools/utils.d.ts +19 -0
  152. package/components/RichTextEditor/tools/utils.js +24 -0
  153. package/components/SearchUI.d.ts +8 -0
  154. package/components/SearchUI.js +59 -0
  155. package/components/SimpleForm/SimpleForm.d.ts +21 -0
  156. package/components/SimpleForm/SimpleForm.js +75 -0
  157. package/components/SimpleForm/index.d.ts +1 -0
  158. package/components/SimpleForm/index.js +1 -0
  159. package/components/SimpleUI/InputField.d.ts +9 -0
  160. package/components/SimpleUI/InputField.js +97 -0
  161. package/components/SingleImageUpload.d.ts +25 -0
  162. package/components/SingleImageUpload.js +102 -0
  163. package/components/SplitView/SplitView.d.ts +10 -0
  164. package/components/SplitView/SplitView.js +76 -0
  165. package/components/SplitView/index.d.ts +1 -0
  166. package/components/SplitView/index.js +1 -0
  167. package/components/index.d.ts +1 -0
  168. package/components/index.js +1 -0
  169. package/hooks/useConfirmationDialog.d.ts +10 -0
  170. package/hooks/useConfirmationDialog.js +47 -0
  171. package/hooks/useDialog.d.ts +5 -0
  172. package/hooks/useDialog.js +27 -0
  173. package/hooks/useSnackbar.d.ts +4 -0
  174. package/hooks/useSnackbar.js +25 -0
  175. package/package.json +101 -0
  176. package/plugins/FileManagerFileTypePlugin.d.ts +33 -0
  177. package/plugins/FileManagerFileTypePlugin.js +46 -0
  178. package/plugins/MenuPlugin.d.ts +20 -0
  179. package/plugins/MenuPlugin.js +41 -0
  180. package/plugins/PermissionRendererPlugin.d.ts +22 -0
  181. package/plugins/PermissionRendererPlugin.js +41 -0
  182. package/plugins/fileManager/fileDefault.d.ts +3 -0
  183. package/plugins/fileManager/fileDefault.js +20 -0
  184. package/plugins/fileManager/fileImage/DeleteAction.d.ts +3 -0
  185. package/plugins/fileManager/fileImage/DeleteAction.js +62 -0
  186. package/plugins/fileManager/fileImage/EditAction.d.ts +9 -0
  187. package/plugins/fileManager/fileImage/EditAction.js +143 -0
  188. package/plugins/fileManager/fileImage/index.d.ts +3 -0
  189. package/plugins/fileManager/fileImage/index.js +29 -0
  190. package/plugins/fileManager/icons/edit.svg +17 -0
  191. package/plugins/fileManager/icons/round-description-24px.svg +1 -0
  192. package/plugins/fileManager/index.d.ts +2 -0
  193. package/plugins/fileManager/index.js +3 -0
  194. package/plugins/globalSearch/SearchBar.d.ts +3 -0
  195. package/plugins/globalSearch/SearchBar.js +241 -0
  196. package/plugins/globalSearch/SearchBarDropdown.d.ts +5 -0
  197. package/plugins/globalSearch/SearchBarDropdown.js +82 -0
  198. package/plugins/globalSearch/icons/round-search-24px.svg +20 -0
  199. package/plugins/globalSearch/index.d.ts +8 -0
  200. package/plugins/globalSearch/index.js +30 -0
  201. package/plugins/globalSearch/styled.d.ts +9 -0
  202. package/plugins/globalSearch/styled.js +115 -0
  203. package/plugins/index.d.ts +6 -0
  204. package/plugins/index.js +8 -0
  205. package/plugins/logo/Logo.d.ts +22 -0
  206. package/plugins/logo/Logo.js +108 -0
  207. package/plugins/logo/index.d.ts +5 -0
  208. package/plugins/logo/index.js +32 -0
  209. package/plugins/menu/documentation.d.ts +4 -0
  210. package/plugins/menu/documentation.js +16 -0
  211. package/plugins/menu/fileManager.d.ts +4 -0
  212. package/plugins/menu/fileManager.js +64 -0
  213. package/plugins/menu/index.d.ts +6 -0
  214. package/plugins/menu/index.js +24 -0
  215. package/plugins/menu/renderers/MenuGroupRenderer.d.ts +7 -0
  216. package/plugins/menu/renderers/MenuGroupRenderer.js +126 -0
  217. package/plugins/menu/renderers/MenuLinkRenderer.d.ts +7 -0
  218. package/plugins/menu/renderers/MenuLinkRenderer.js +52 -0
  219. package/plugins/menu/renderers/MenuSectionItemRenderer.d.ts +7 -0
  220. package/plugins/menu/renderers/MenuSectionItemRenderer.js +77 -0
  221. package/plugins/menu/renderers/MenuSectionRenderer.d.ts +7 -0
  222. package/plugins/menu/renderers/MenuSectionRenderer.js +51 -0
  223. package/plugins/menu/slack.d.ts +4 -0
  224. package/plugins/menu/slack.js +16 -0
  225. package/plugins/menu/source.d.ts +4 -0
  226. package/plugins/menu/source.js +16 -0
  227. package/plugins/uiLayoutRenderer/index.d.ts +3 -0
  228. package/plugins/uiLayoutRenderer/index.js +63 -0
  229. package/plugins/userMenu/UserMenuElement.d.ts +7 -0
  230. package/plugins/userMenu/UserMenuElement.js +43 -0
  231. package/plugins/userMenu/UserMenuRenderer.d.ts +6 -0
  232. package/plugins/userMenu/UserMenuRenderer.js +47 -0
  233. package/plugins/userMenu/index.d.ts +4 -0
  234. package/plugins/userMenu/index.js +16 -0
  235. package/styles/material-theme-assignments.scss +333 -0
  236. package/styles/material.scss +74 -0
  237. package/styles/theme.scss +43 -0
  238. package/styles.scss +2 -0
  239. package/types.d.ts +100 -0
  240. package/types.js +1 -0
  241. package/ui/UIElement.d.ts +2 -0
  242. package/ui/UIElement.js +1 -0
  243. package/ui/UILayout.d.ts +1 -0
  244. package/ui/UILayout.js +1 -0
  245. package/ui/UIRenderer.d.ts +2 -0
  246. package/ui/UIRenderer.js +1 -0
  247. package/ui/UIView.d.ts +2 -0
  248. package/ui/UIView.js +1 -0
  249. package/ui/elements/AccordionElement.d.ts +27 -0
  250. package/ui/elements/AccordionElement.js +86 -0
  251. package/ui/elements/ButtonElement.d.ts +24 -0
  252. package/ui/elements/ButtonElement.js +78 -0
  253. package/ui/elements/ButtonGroupElement.d.ts +6 -0
  254. package/ui/elements/ButtonGroupElement.js +48 -0
  255. package/ui/elements/GenericElement.d.ts +1 -0
  256. package/ui/elements/GenericElement.js +1 -0
  257. package/ui/elements/LabelElement.d.ts +16 -0
  258. package/ui/elements/LabelElement.js +47 -0
  259. package/ui/elements/NavigationMenuElement.d.ts +32 -0
  260. package/ui/elements/NavigationMenuElement.js +158 -0
  261. package/ui/elements/PanelElement.d.ts +3 -0
  262. package/ui/elements/PanelElement.js +17 -0
  263. package/ui/elements/PlaceholderElement.d.ts +5 -0
  264. package/ui/elements/PlaceholderElement.js +30 -0
  265. package/ui/elements/SmallButtonElement.d.ts +6 -0
  266. package/ui/elements/SmallButtonElement.js +47 -0
  267. package/ui/elements/TypographyElement.d.ts +13 -0
  268. package/ui/elements/TypographyElement.js +49 -0
  269. package/ui/elements/ViewElement.d.ts +1 -0
  270. package/ui/elements/ViewElement.js +1 -0
  271. package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.d.ts +6 -0
  272. package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.js +44 -0
  273. package/ui/elements/form/DynamicFieldsetElement.d.ts +42 -0
  274. package/ui/elements/form/DynamicFieldsetElement.js +127 -0
  275. package/ui/elements/form/FileManagerElement/EmptyStateElement.d.ts +4 -0
  276. package/ui/elements/form/FileManagerElement/EmptyStateElement.js +24 -0
  277. package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.d.ts +7 -0
  278. package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.js +72 -0
  279. package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.d.ts +13 -0
  280. package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.js +95 -0
  281. package/ui/elements/form/FileManagerElement/styled.d.ts +14 -0
  282. package/ui/elements/form/FileManagerElement/styled.js +106 -0
  283. package/ui/elements/form/FileManagerElement.d.ts +24 -0
  284. package/ui/elements/form/FileManagerElement.js +91 -0
  285. package/ui/elements/form/FormElement.d.ts +21 -0
  286. package/ui/elements/form/FormElement.js +45 -0
  287. package/ui/elements/form/FormFieldElement.d.ts +55 -0
  288. package/ui/elements/form/FormFieldElement.js +183 -0
  289. package/ui/elements/form/HiddenElement.d.ts +6 -0
  290. package/ui/elements/form/HiddenElement.js +49 -0
  291. package/ui/elements/form/InputElement.d.ts +6 -0
  292. package/ui/elements/form/InputElement.js +55 -0
  293. package/ui/elements/form/PasswordElement.d.ts +6 -0
  294. package/ui/elements/form/PasswordElement.js +50 -0
  295. package/ui/elements/form/README.md +2 -0
  296. package/ui/elements/form/SelectElement.d.ts +15 -0
  297. package/ui/elements/form/SelectElement.js +71 -0
  298. package/ui/elements/form/TextareaElement.d.ts +15 -0
  299. package/ui/elements/form/TextareaElement.js +56 -0
  300. package/ui/views/AdminView/ContentElement.d.ts +4 -0
  301. package/ui/views/AdminView/ContentElement.js +62 -0
  302. package/ui/views/AdminView/HeaderElement.d.ts +13 -0
  303. package/ui/views/AdminView/HeaderElement.js +111 -0
  304. package/ui/views/AdminView/HeaderSectionCenterElement.d.ts +6 -0
  305. package/ui/views/AdminView/HeaderSectionCenterElement.js +42 -0
  306. package/ui/views/AdminView/HeaderSectionLeftElement.d.ts +6 -0
  307. package/ui/views/AdminView/HeaderSectionLeftElement.js +42 -0
  308. package/ui/views/AdminView/HeaderSectionRightElement.d.ts +6 -0
  309. package/ui/views/AdminView/HeaderSectionRightElement.js +42 -0
  310. package/ui/views/AdminView/components/Dialog.d.ts +2 -0
  311. package/ui/views/AdminView/components/Dialog.js +40 -0
  312. package/ui/views/AdminView/components/Hamburger.d.ts +3 -0
  313. package/ui/views/AdminView/components/Hamburger.js +25 -0
  314. package/ui/views/AdminView/components/Snackbar.d.ts +3 -0
  315. package/ui/views/AdminView/components/Snackbar.js +28 -0
  316. package/ui/views/AdminView.d.ts +12 -0
  317. package/ui/views/AdminView.js +90 -0
  318. package/ui/views/FormView/FormContainerElement.d.ts +12 -0
  319. package/ui/views/FormView/FormContainerElement.js +51 -0
  320. package/ui/views/FormView/FormContentElement.d.ts +3 -0
  321. package/ui/views/FormView/FormContentElement.js +17 -0
  322. package/ui/views/FormView/FormFooterElement.d.ts +6 -0
  323. package/ui/views/FormView/FormFooterElement.js +49 -0
  324. package/ui/views/FormView/FormHeaderElement.d.ts +14 -0
  325. package/ui/views/FormView/FormHeaderElement.js +81 -0
  326. package/ui/views/FormView.d.ts +40 -0
  327. package/ui/views/FormView.js +160 -0
  328. package/ui/views/NavigationView/ContentElement.d.ts +10 -0
  329. package/ui/views/NavigationView/ContentElement.js +86 -0
  330. package/ui/views/NavigationView/FooterElement.d.ts +13 -0
  331. package/ui/views/NavigationView/FooterElement.js +57 -0
  332. package/ui/views/NavigationView/HeaderElement.d.ts +16 -0
  333. package/ui/views/NavigationView/HeaderElement.js +66 -0
  334. package/ui/views/NavigationView/NavigationViewRenderer.d.ts +6 -0
  335. package/ui/views/NavigationView/NavigationViewRenderer.js +38 -0
  336. package/ui/views/NavigationView/Styled.d.ts +7 -0
  337. package/ui/views/NavigationView/Styled.js +47 -0
  338. package/ui/views/NavigationView/legacyMenu.d.ts +22 -0
  339. package/ui/views/NavigationView/legacyMenu.js +1 -0
  340. package/ui/views/NavigationView/useNavigation.d.ts +6 -0
  341. package/ui/views/NavigationView/useNavigation.js +22 -0
  342. package/ui/views/NavigationView.d.ts +26 -0
  343. package/ui/views/NavigationView.js +204 -0
  344. package/ui/views/OverlayView/ContentElement.d.ts +6 -0
  345. package/ui/views/OverlayView/ContentElement.js +42 -0
  346. package/ui/views/OverlayView/HeaderElement.d.ts +24 -0
  347. package/ui/views/OverlayView/HeaderElement.js +115 -0
  348. package/ui/views/OverlayView/HeaderTitleElement.d.ts +13 -0
  349. package/ui/views/OverlayView/HeaderTitleElement.js +54 -0
  350. package/ui/views/OverlayView/useOverlayView.d.ts +6 -0
  351. package/ui/views/OverlayView/useOverlayView.js +38 -0
  352. package/ui/views/OverlayView.d.ts +31 -0
  353. package/ui/views/OverlayView.js +176 -0
  354. package/ui/views/SplitView/SplitViewPanelElement.d.ts +11 -0
  355. package/ui/views/SplitView/SplitViewPanelElement.js +72 -0
  356. package/ui/views/SplitView.d.ts +21 -0
  357. package/ui/views/SplitView.js +142 -0
@@ -0,0 +1,129 @@
1
+ import React from "react";
2
+ import LazyLoad from "react-lazy-load";
3
+ import classNames from "classnames";
4
+ import { css, keyframes } from "emotion";
5
+ import { Ripple } from "@webiny/ui/Ripple";
6
+ import { IconButton } from "@webiny/ui/Button";
7
+ import { ReactComponent as Checked } from "@svgr/webpack!./icons/round-check_box-24px.svg";
8
+ import { ReactComponent as SettingsIcon } from "@svgr/webpack!../../assets/icons/round-settings-24px.svg";
9
+ var COMPONENT_WIDTH = 200;
10
+ var COMPONENT_HEIGHT = 200;
11
+ var grow = /*#__PURE__*/keyframes("0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}label:grow;");
12
+ var styles = /*#__PURE__*/css({
13
+ display: "inline-block",
14
+ float: "left",
15
+ position: "relative",
16
+ zIndex: 1,
17
+ margin: 10,
18
+ cursor: "pointer",
19
+ width: "100%",
20
+ maxWidth: COMPONENT_WIDTH,
21
+ border: "1px solid var(--mdc-theme-on-background)",
22
+ borderRadius: 2,
23
+ "> .body": {
24
+ transition: "200ms ease-in opacity",
25
+ width: COMPONENT_WIDTH,
26
+ height: COMPONENT_HEIGHT,
27
+ overflow: "hidden",
28
+ "--icon-color": "var(--mdc-theme-on-background)",
29
+ ".checkedIcon": {
30
+ color: "var(--mdc-theme-secondary)",
31
+ position: "absolute",
32
+ top: 4,
33
+ left: 4,
34
+ zIndex: 11
35
+ },
36
+ ".infoIcon": {
37
+ opacity: 0,
38
+ position: "absolute",
39
+ top: 0,
40
+ right: 0,
41
+ zIndex: 10,
42
+ transition: "all 150ms ease-in",
43
+ "& .mdc-icon-button svg": {
44
+ color: "var(--mdc-theme-secondary)"
45
+ },
46
+ "&:hover": {
47
+ animationName: grow,
48
+ animationDuration: ".4s",
49
+ animationTimingFunction: "ease-in",
50
+ animationDelay: ".2s"
51
+ }
52
+ },
53
+ ".filePreview": {
54
+ textAlign: "center",
55
+ position: "relative",
56
+ backgroundColor: "#fff",
57
+ width: "100%",
58
+ height: "100%",
59
+ ".clickableArea": {
60
+ position: "absolute",
61
+ top: 30,
62
+ left: 0,
63
+ width: "100%",
64
+ height: 170,
65
+ zIndex: 2
66
+ }
67
+ },
68
+ "&:hover .infoIcon": {
69
+ opacity: 1
70
+ }
71
+ },
72
+ "> .label": {
73
+ padding: "15px 10px",
74
+ whiteSpace: "nowrap",
75
+ overflow: "hidden",
76
+ textOverflow: "ellipsis",
77
+ fontSize: "0.8rem",
78
+ color: "var(--mdc-theme-on-surface)",
79
+ backgroundColor: "var(--mdc-theme-on-background)"
80
+ },
81
+ "&.disable-select": {
82
+ cursor: "auto"
83
+ }
84
+ }, "label:styles;");
85
+ export default /*#__PURE__*/React.memo(function File(props) {
86
+ var file = props.file,
87
+ selected = props.selected,
88
+ onSelect = props.onSelect,
89
+ children = props.children,
90
+ showFileDetails = props.showFileDetails;
91
+ return /*#__PURE__*/React.createElement("div", {
92
+ className: classNames(styles, {
93
+ "disable-select": !onSelect
94
+ }),
95
+ "data-testid": "fm-list-wrapper-file"
96
+ }, /*#__PURE__*/React.createElement("div", {
97
+ className: "body"
98
+ }, /*#__PURE__*/React.createElement("div", {
99
+ className: "checkedIcon",
100
+ onClick: onSelect
101
+ }, selected ? /*#__PURE__*/React.createElement(Checked, null) : null), /*#__PURE__*/React.createElement("div", {
102
+ className: "infoIcon"
103
+ }, /*#__PURE__*/React.createElement(IconButton, {
104
+ icon: /*#__PURE__*/React.createElement(SettingsIcon, null),
105
+ onClick: showFileDetails,
106
+ "data-testid": "fm-file-wrapper-file-info-icon"
107
+ })), /*#__PURE__*/React.createElement(LazyLoad, {
108
+ height: 200,
109
+ offsetVertical: 300
110
+ }, /*#__PURE__*/React.createElement(Ripple, null, /*#__PURE__*/React.createElement("div", {
111
+ className: "filePreview"
112
+ }, /*#__PURE__*/React.createElement("div", {
113
+ className: "clickableArea",
114
+ onClick: onSelect
115
+ }), children)))), /*#__PURE__*/React.createElement("div", {
116
+ className: "label",
117
+ onClick: onSelect
118
+ }, file.name));
119
+ }, function (prev, next) {
120
+ if (prev.selected !== next.selected) {
121
+ return false;
122
+ }
123
+
124
+ if (prev.file.name !== next.file.name) {
125
+ return false;
126
+ }
127
+
128
+ return true;
129
+ });
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ declare function Name({ file, canEdit }: {
3
+ file: any;
4
+ canEdit: any;
5
+ }): JSX.Element;
6
+ export default Name;
@@ -0,0 +1,113 @@
1
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _cloneDeep from "lodash/cloneDeep";
3
+ import _get from "lodash/get";
4
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
5
+ import React, { useMemo } from "react";
6
+ import { useApolloClient } from "@apollo/react-hooks";
7
+ import { Input } from "@webiny/ui/Input";
8
+ import { Form } from "@webiny/form";
9
+ import { validation } from "@webiny/validation";
10
+ import { useSnackbar } from "../../../hooks/useSnackbar";
11
+ import { UPDATE_FILE, LIST_FILES } from "./../graphql";
12
+ import { useFileManager } from "./../FileManagerContext";
13
+
14
+ function Name(_ref) {
15
+ var file = _ref.file,
16
+ canEdit = _ref.canEdit;
17
+ var name = file.name || "";
18
+
19
+ var _useSnackbar = useSnackbar(),
20
+ showSnackbar = _useSnackbar.showSnackbar;
21
+
22
+ var client = useApolloClient();
23
+
24
+ var _useFileManager = useFileManager(),
25
+ queryParams = _useFileManager.queryParams;
26
+
27
+ var editContent = useMemo(function () {
28
+ return /*#__PURE__*/React.createElement(Form, {
29
+ data: {
30
+ name: name
31
+ },
32
+ onSubmit: /*#__PURE__*/function () {
33
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(_ref2) {
34
+ var name;
35
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
36
+ while (1) {
37
+ switch (_context.prev = _context.next) {
38
+ case 0:
39
+ name = _ref2.name;
40
+
41
+ if (!(name === file.name)) {
42
+ _context.next = 3;
43
+ break;
44
+ }
45
+
46
+ return _context.abrupt("return");
47
+
48
+ case 3:
49
+ _context.next = 5;
50
+ return client.mutate({
51
+ mutation: UPDATE_FILE,
52
+ variables: {
53
+ id: file.id,
54
+ data: {
55
+ name: name
56
+ }
57
+ },
58
+ update: function update(cache, updated) {
59
+ var newFileData = _get(updated, "data.fileManager.updateFile.data");
60
+
61
+ var data = _cloneDeep(cache.readQuery({
62
+ query: LIST_FILES,
63
+ variables: queryParams
64
+ }));
65
+
66
+ data.fileManager.listFiles.data.forEach(function (item) {
67
+ if (item.src === newFileData.src) {
68
+ item.name = newFileData.name;
69
+ }
70
+ });
71
+ cache.writeQuery({
72
+ query: LIST_FILES,
73
+ variables: queryParams,
74
+ data: data
75
+ });
76
+ }
77
+ });
78
+
79
+ case 5:
80
+ showSnackbar("Name successfully updated.");
81
+
82
+ case 6:
83
+ case "end":
84
+ return _context.stop();
85
+ }
86
+ }
87
+ }, _callee);
88
+ }));
89
+
90
+ return function (_x) {
91
+ return _ref3.apply(this, arguments);
92
+ };
93
+ }()
94
+ }, function (_ref4) {
95
+ var Bind = _ref4.Bind,
96
+ submit = _ref4.submit;
97
+ return /*#__PURE__*/React.createElement(Bind, {
98
+ name: "name",
99
+ validators: validation.create("required")
100
+ }, /*#__PURE__*/React.createElement(Input, {
101
+ disabled: !canEdit(file),
102
+ autoFocus: true,
103
+ placeholder: "Enter name",
104
+ fullwidth: true,
105
+ onBlur: submit,
106
+ description: "A descriptive name is easier to remember."
107
+ }));
108
+ });
109
+ }, [name, file.name, canEdit]);
110
+ return /*#__PURE__*/React.createElement("li-content", null, editContent);
111
+ }
112
+
113
+ export default Name;
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ declare function Tags({ file, canEdit }: {
3
+ file: any;
4
+ canEdit: any;
5
+ }): JSX.Element;
6
+ export default Tags;
@@ -0,0 +1,241 @@
1
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
5
+ import React, { useCallback, useState } from "react";
6
+ import classNames from "classnames";
7
+ import { css } from "emotion";
8
+ import { useApolloClient, useQuery } from "@apollo/react-hooks";
9
+ import set from "lodash/set";
10
+ import get from "lodash/get";
11
+ import cloneDeep from "lodash/cloneDeep";
12
+ import { Chips, Chip } from "@webiny/ui/Chips";
13
+ import { ButtonSecondary, ButtonPrimary, ButtonDefault, IconButton } from "@webiny/ui/Button";
14
+ import { MultiAutoComplete } from "@webiny/ui/AutoComplete";
15
+ import { Icon } from "@webiny/ui/Icon";
16
+ import { Form } from "@webiny/form";
17
+ import { useSnackbar } from "../../../hooks/useSnackbar";
18
+ import { useFileManager } from "./../FileManagerContext";
19
+ import { UPDATE_FILE, LIST_FILES, LIST_TAGS } from "./../graphql";
20
+ import { ReactComponent as EditIcon } from "@svgr/webpack!./../icons/round-edit-24px.svg";
21
+ import { ReactComponent as LabelIcon } from "@svgr/webpack!./../icons/round-label-24px.svg";
22
+ var chipsStyle = /*#__PURE__*/css({
23
+ "&.mdc-chip-set": {
24
+ padding: 0,
25
+ marginLeft: -4,
26
+ "& .mdc-chip": {
27
+ backgroundColor: "var(--mdc-theme-background)"
28
+ }
29
+ }
30
+ }, "label:chipsStyle;");
31
+ var iconButtonStyle = /*#__PURE__*/css({
32
+ "&.mdc-icon-button svg": {
33
+ width: 20,
34
+ height: 20
35
+ }
36
+ }, "label:iconButtonStyle;");
37
+ var addTagsStyle = /*#__PURE__*/css({
38
+ "&.mdc-button:not(:disabled)": {
39
+ color: "var(--mdc-theme-text-secondary-on-background)",
40
+ textTransform: "capitalize",
41
+ letterSpacing: "initial",
42
+ marginLeft: -8
43
+ }
44
+ }, "label:addTagsStyle;");
45
+ var actionWrapperStyle = /*#__PURE__*/css({
46
+ marginTop: 16,
47
+ "& button:first-child": {
48
+ marginRight: 16
49
+ }
50
+ }, "label:actionWrapperStyle;");
51
+
52
+ function Tags(_ref) {
53
+ var file = _ref.file,
54
+ canEdit = _ref.canEdit;
55
+ var client = useApolloClient();
56
+
57
+ var _useState = useState(false),
58
+ _useState2 = _slicedToArray(_useState, 2),
59
+ editing = _useState2[0],
60
+ setEdit = _useState2[1];
61
+
62
+ var _useState3 = useState(false),
63
+ _useState4 = _slicedToArray(_useState3, 2),
64
+ saving = _useState4[0],
65
+ setSaving = _useState4[1];
66
+
67
+ var _useState5 = useState(Array.isArray(file.tags) ? _toConsumableArray(file.tags) : []),
68
+ _useState6 = _slicedToArray(_useState5, 2),
69
+ initialTags = _useState6[0],
70
+ setInitialTags = _useState6[1];
71
+
72
+ var _useSnackbar = useSnackbar(),
73
+ showSnackbar = _useSnackbar.showSnackbar;
74
+
75
+ var _useFileManager = useFileManager(),
76
+ queryParams = _useFileManager.queryParams;
77
+
78
+ var handleEdit = useCallback(function () {
79
+ return setEdit(true);
80
+ }, []);
81
+ var listTagsQuery = useQuery(LIST_TAGS);
82
+ var allTags = get(listTagsQuery, "data.fileManager.listTags") || [];
83
+ var isEditingAllowed = canEdit(file);
84
+ var renderHeaderContent = useCallback(function (_ref2) {
85
+ var data = _ref2.data;
86
+
87
+ if (editing) {
88
+ return null;
89
+ }
90
+
91
+ var hasTags = data.tags.length > 0;
92
+
93
+ if (hasTags) {
94
+ // Render existing tags and "edit tags" action.
95
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Chips, {
96
+ className: classNames("list-item__content", chipsStyle)
97
+ }, data.tags.map(function (tag, index) {
98
+ var label = typeof tag === "string" ? tag : tag.name;
99
+ return /*#__PURE__*/React.createElement(Chip, {
100
+ key: label + index,
101
+ label: label
102
+ });
103
+ })), isEditingAllowed && /*#__PURE__*/React.createElement(IconButton, {
104
+ className: iconButtonStyle,
105
+ icon: /*#__PURE__*/React.createElement(EditIcon, null),
106
+ onClick: handleEdit
107
+ }));
108
+ } // Render "add tags" action.
109
+
110
+
111
+ return /*#__PURE__*/React.createElement(ButtonDefault, {
112
+ className: addTagsStyle,
113
+ onClick: handleEdit,
114
+ disabled: !isEditingAllowed
115
+ }, "Add tags...");
116
+ }, [editing, isEditingAllowed]);
117
+ return /*#__PURE__*/React.createElement(Form, {
118
+ data: {
119
+ tags: initialTags
120
+ },
121
+ onSubmit: /*#__PURE__*/function () {
122
+ var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(_ref3) {
123
+ var tags;
124
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
125
+ while (1) {
126
+ switch (_context.prev = _context.next) {
127
+ case 0:
128
+ tags = _ref3.tags;
129
+ setSaving(true);
130
+ client.mutate({
131
+ mutation: UPDATE_FILE,
132
+ variables: {
133
+ id: file.id,
134
+ data: {
135
+ tags: tags
136
+ }
137
+ },
138
+ update: function update(cache, updated) {
139
+ var newFileData = get(updated, "data.fileManager.updateFile.data"); // 1. Update files list cache
140
+
141
+ var data = cloneDeep(cache.readQuery({
142
+ query: LIST_FILES,
143
+ variables: queryParams
144
+ }));
145
+ data.fileManager.listFiles.data.forEach(function (item) {
146
+ if (item.key === newFileData.key) {
147
+ item.tags = newFileData.tags;
148
+ }
149
+ });
150
+ cache.writeQuery({
151
+ query: LIST_FILES,
152
+ variables: queryParams,
153
+ data: data
154
+ }); // 2. Update "LIST_TAGS" cache
155
+
156
+ if (Array.isArray(newFileData.tags)) {
157
+ // Get list tags data
158
+ var listTagsData = cloneDeep(cache.readQuery({
159
+ query: LIST_TAGS
160
+ })); // Add new tag in list
161
+
162
+ var updatedTagsList = _toConsumableArray(newFileData.tags);
163
+
164
+ if (Array.isArray(listTagsData.fileManager.listTags)) {
165
+ listTagsData.fileManager.listTags.forEach(function (tag) {
166
+ if (!updatedTagsList.includes(tag)) {
167
+ updatedTagsList.push(tag);
168
+ }
169
+ });
170
+ }
171
+
172
+ set(listTagsData, "fileManager.listTags", updatedTagsList); // Write it to cache
173
+
174
+ cache.writeQuery({
175
+ query: LIST_TAGS,
176
+ data: listTagsData
177
+ });
178
+ }
179
+ }
180
+ }).then(function () {
181
+ setInitialTags(tags);
182
+ setSaving(false);
183
+ setEdit(false);
184
+ showSnackbar("Tags successfully updated.");
185
+ });
186
+
187
+ case 3:
188
+ case "end":
189
+ return _context.stop();
190
+ }
191
+ }
192
+ }, _callee);
193
+ }));
194
+
195
+ return function (_x) {
196
+ return _ref4.apply(this, arguments);
197
+ };
198
+ }()
199
+ }, function (_ref5) {
200
+ var Bind = _ref5.Bind,
201
+ data = _ref5.data,
202
+ setValue = _ref5.setValue,
203
+ submit = _ref5.submit;
204
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("li-title", null, /*#__PURE__*/React.createElement(Icon, {
205
+ className: "list-item__icon",
206
+ icon: /*#__PURE__*/React.createElement(LabelIcon, null)
207
+ }), renderHeaderContent({
208
+ data: data
209
+ })), editing && /*#__PURE__*/React.createElement("li-content", null, /*#__PURE__*/React.createElement(Bind, {
210
+ name: "tags",
211
+ beforeChange: function beforeChange(tags, baseOnChange) {
212
+ var formattedTags = tags.map(function (tag) {
213
+ return tag.toLowerCase();
214
+ });
215
+ baseOnChange(formattedTags);
216
+ }
217
+ }, /*#__PURE__*/React.createElement(MultiAutoComplete, {
218
+ options: allTags,
219
+ placeholder: "homepage asset",
220
+ description: "Type in a new tag or select an existing one.",
221
+ unique: true,
222
+ allowFreeInput: true,
223
+ useSimpleValues: true,
224
+ disabled: saving
225
+ })), /*#__PURE__*/React.createElement("div", {
226
+ className: actionWrapperStyle
227
+ }, /*#__PURE__*/React.createElement(ButtonPrimary, {
228
+ small: true,
229
+ onClick: submit,
230
+ "data-testid": "fm.tags.submit"
231
+ }, "Submit"), /*#__PURE__*/React.createElement(ButtonSecondary, {
232
+ small: true,
233
+ onClick: function onClick() {
234
+ setValue("tags", initialTags);
235
+ setEdit(false);
236
+ }
237
+ }, "Cancel"))));
238
+ });
239
+ }
240
+
241
+ export default Tags;
@@ -0,0 +1,23 @@
1
+ import React from "react";
2
+ declare global {
3
+ namespace JSX {
4
+ interface IntrinsicElements {
5
+ "li-title": {
6
+ children?: React.ReactNode;
7
+ };
8
+ "li-content": {
9
+ children?: React.ReactNode;
10
+ };
11
+ }
12
+ }
13
+ }
14
+ declare type FileDetailsProps = {
15
+ canEdit: (item: any) => boolean;
16
+ file: {
17
+ name: string;
18
+ [key: string]: any;
19
+ };
20
+ [key: string]: any;
21
+ };
22
+ export default function FileDetails(props: FileDetailsProps): JSX.Element;
23
+ export {};