@webiny/app-admin 0.0.0-ee-vpcs.549378cf03

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 (499) 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/base/Admin.d.ts +7 -0
  51. package/base/Admin.js +55 -0
  52. package/base/Admin.js.map +1 -0
  53. package/base/Base.d.ts +2 -0
  54. package/base/Base.js +110 -0
  55. package/base/Base.js.map +1 -0
  56. package/base/plugins/AddGraphQLQuerySelection.d.ts +9 -0
  57. package/base/plugins/AddGraphQLQuerySelection.js +31 -0
  58. package/base/plugins/AddGraphQLQuerySelection.js.map +1 -0
  59. package/base/providers/ApolloProvider.d.ts +10 -0
  60. package/base/providers/ApolloProvider.js +26 -0
  61. package/base/providers/ApolloProvider.js.map +1 -0
  62. package/base/providers/TelemetryProvider.d.ts +2 -0
  63. package/base/providers/TelemetryProvider.js +37 -0
  64. package/base/providers/TelemetryProvider.js.map +1 -0
  65. package/base/providers/UiStateProvider.d.ts +2 -0
  66. package/base/providers/UiStateProvider.js +23 -0
  67. package/base/providers/UiStateProvider.js.map +1 -0
  68. package/base/providers/ViewCompositionProvider.d.ts +17 -0
  69. package/base/providers/ViewCompositionProvider.js +70 -0
  70. package/base/providers/ViewCompositionProvider.js.map +1 -0
  71. package/base/ui/Brand.d.ts +2 -0
  72. package/base/ui/Brand.js +19 -0
  73. package/base/ui/Brand.js.map +1 -0
  74. package/base/ui/CenteredView.d.ts +4 -0
  75. package/base/ui/CenteredView.js +40 -0
  76. package/base/ui/CenteredView.js.map +1 -0
  77. package/base/ui/Dashboard.d.ts +2 -0
  78. package/base/ui/Dashboard.js +19 -0
  79. package/base/ui/Dashboard.js.map +1 -0
  80. package/base/ui/Layout.d.ts +7 -0
  81. package/base/ui/Layout.js +24 -0
  82. package/base/ui/Layout.js.map +1 -0
  83. package/base/ui/LocaleSelector.d.ts +2 -0
  84. package/base/ui/LocaleSelector.js +19 -0
  85. package/base/ui/LocaleSelector.js.map +1 -0
  86. package/base/ui/LoginScreen.d.ts +6 -0
  87. package/base/ui/LoginScreen.js +27 -0
  88. package/base/ui/LoginScreen.js.map +1 -0
  89. package/base/ui/Logo.d.ts +8 -0
  90. package/base/ui/Logo.js +36 -0
  91. package/base/ui/Logo.js.map +1 -0
  92. package/base/ui/Menu.d.ts +31 -0
  93. package/base/ui/Menu.js +166 -0
  94. package/base/ui/Menu.js.map +1 -0
  95. package/base/ui/Navigation.d.ts +24 -0
  96. package/base/ui/Navigation.js +184 -0
  97. package/base/ui/Navigation.js.map +1 -0
  98. package/base/ui/NotFound.d.ts +2 -0
  99. package/base/ui/NotFound.js +19 -0
  100. package/base/ui/NotFound.js.map +1 -0
  101. package/base/ui/Search.d.ts +19 -0
  102. package/base/ui/Search.js +81 -0
  103. package/base/ui/Search.js.map +1 -0
  104. package/base/ui/Tags.d.ts +10 -0
  105. package/base/ui/Tags.js +29 -0
  106. package/base/ui/Tags.js.map +1 -0
  107. package/base/ui/UserMenu.d.ts +30 -0
  108. package/base/ui/UserMenu.js +137 -0
  109. package/base/ui/UserMenu.js.map +1 -0
  110. package/components/AdminLayout.d.ts +6 -0
  111. package/components/AdminLayout.js +22 -0
  112. package/components/AdminLayout.js.map +1 -0
  113. package/components/AppInstaller/AppInstaller.d.ts +7 -0
  114. package/components/AppInstaller/AppInstaller.js +183 -0
  115. package/components/AppInstaller/AppInstaller.js.map +1 -0
  116. package/components/AppInstaller/Sidebar.d.ts +9 -0
  117. package/components/AppInstaller/Sidebar.js +178 -0
  118. package/components/AppInstaller/Sidebar.js.map +1 -0
  119. package/components/AppInstaller/assets/sign-in-divider.svg +19 -0
  120. package/components/AppInstaller/index.d.ts +2 -0
  121. package/components/AppInstaller/index.js +29 -0
  122. package/components/AppInstaller/index.js.map +1 -0
  123. package/components/AppInstaller/styled.d.ts +9 -0
  124. package/components/AppInstaller/styled.js +91 -0
  125. package/components/AppInstaller/styled.js.map +1 -0
  126. package/components/AppInstaller/useInstaller.d.ts +31 -0
  127. package/components/AppInstaller/useInstaller.js +321 -0
  128. package/components/AppInstaller/useInstaller.js.map +1 -0
  129. package/components/EmptyView.d.ts +8 -0
  130. package/components/EmptyView.js +70 -0
  131. package/components/EmptyView.js.map +1 -0
  132. package/components/FileManager/BottomInfoBar/SupportedFileTypes.d.ts +6 -0
  133. package/components/FileManager/BottomInfoBar/SupportedFileTypes.js +55 -0
  134. package/components/FileManager/BottomInfoBar/SupportedFileTypes.js.map +1 -0
  135. package/components/FileManager/BottomInfoBar/UploadStatus.d.ts +6 -0
  136. package/components/FileManager/BottomInfoBar/UploadStatus.js +60 -0
  137. package/components/FileManager/BottomInfoBar/UploadStatus.js.map +1 -0
  138. package/components/FileManager/BottomInfoBar.d.ts +5 -0
  139. package/components/FileManager/BottomInfoBar.js +60 -0
  140. package/components/FileManager/BottomInfoBar.js.map +1 -0
  141. package/components/FileManager/DropFilesHere.d.ts +10 -0
  142. package/components/FileManager/DropFilesHere.js +76 -0
  143. package/components/FileManager/DropFilesHere.js.map +1 -0
  144. package/components/FileManager/File.d.ts +17 -0
  145. package/components/FileManager/File.js +155 -0
  146. package/components/FileManager/File.js.map +1 -0
  147. package/components/FileManager/FileDetails/Name.d.ts +8 -0
  148. package/components/FileManager/FileDetails/Name.js +138 -0
  149. package/components/FileManager/FileDetails/Name.js.map +1 -0
  150. package/components/FileManager/FileDetails/Tags.d.ts +10 -0
  151. package/components/FileManager/FileDetails/Tags.js +339 -0
  152. package/components/FileManager/FileDetails/Tags.js.map +1 -0
  153. package/components/FileManager/FileDetails.d.ts +24 -0
  154. package/components/FileManager/FileDetails.js +474 -0
  155. package/components/FileManager/FileDetails.js.map +1 -0
  156. package/components/FileManager/FileManagerContext.d.ts +42 -0
  157. package/components/FileManager/FileManagerContext.js +224 -0
  158. package/components/FileManager/FileManagerContext.js.map +1 -0
  159. package/components/FileManager/FileManagerView.d.ts +18 -0
  160. package/components/FileManager/FileManagerView.js +728 -0
  161. package/components/FileManager/FileManagerView.js.map +1 -0
  162. package/components/FileManager/LeftSidebar.d.ts +10 -0
  163. package/components/FileManager/LeftSidebar.js +127 -0
  164. package/components/FileManager/LeftSidebar.js.map +1 -0
  165. package/components/FileManager/NoPermissionView.d.ts +3 -0
  166. package/components/FileManager/NoPermissionView.js +87 -0
  167. package/components/FileManager/NoPermissionView.js.map +1 -0
  168. package/components/FileManager/NoResults.d.ts +3 -0
  169. package/components/FileManager/NoResults.js +28 -0
  170. package/components/FileManager/NoResults.js.map +1 -0
  171. package/components/FileManager/getFileTypePlugin.d.ts +4 -0
  172. package/components/FileManager/getFileTypePlugin.js +57 -0
  173. package/components/FileManager/getFileTypePlugin.js.map +1 -0
  174. package/components/FileManager/getFileUploader.d.ts +3 -0
  175. package/components/FileManager/getFileUploader.js +20 -0
  176. package/components/FileManager/getFileUploader.js.map +1 -0
  177. package/components/FileManager/graphql.d.ts +96 -0
  178. package/components/FileManager/graphql.js +58 -0
  179. package/components/FileManager/graphql.js.map +1 -0
  180. package/components/FileManager/icons/content_copy-black-24px.svg +1 -0
  181. package/components/FileManager/icons/delete.svg +12 -0
  182. package/components/FileManager/icons/privacy_tip-24px.svg +10 -0
  183. package/components/FileManager/icons/round-check_box-24px.svg +4 -0
  184. package/components/FileManager/icons/round-check_box_outline_blank-24px.svg +4 -0
  185. package/components/FileManager/icons/round-cloud_download-24px.svg +4 -0
  186. package/components/FileManager/icons/round-cloud_upload-24px.svg +4 -0
  187. package/components/FileManager/icons/round-description-24px.svg +4 -0
  188. package/components/FileManager/icons/round-edit-24px.svg +4 -0
  189. package/components/FileManager/icons/round-info-24px.svg +4 -0
  190. package/components/FileManager/icons/round-label-24px.svg +4 -0
  191. package/components/FileManager/icons/round-more_vert-24px.svg +4 -0
  192. package/components/FileManager/icons/round-search-24px.svg +20 -0
  193. package/components/FileManager/outputFileSelectionError.d.ts +7 -0
  194. package/components/FileManager/outputFileSelectionError.js +54 -0
  195. package/components/FileManager/outputFileSelectionError.js.map +1 -0
  196. package/components/FileManager/types.d.ts +21 -0
  197. package/components/FileManager/types.js +5 -0
  198. package/components/FileManager/types.js.map +1 -0
  199. package/components/FileManager.d.ts +67 -0
  200. package/components/FileManager.js +144 -0
  201. package/components/FileManager.js.map +1 -0
  202. package/components/FloatingActionButton.d.ts +3 -0
  203. package/components/FloatingActionButton.js +29 -0
  204. package/components/FloatingActionButton.js.map +1 -0
  205. package/components/MultiImageUpload.d.ts +13 -0
  206. package/components/MultiImageUpload.js +43 -0
  207. package/components/MultiImageUpload.js.map +1 -0
  208. package/components/OverlayLayout/OverlayLayout.d.ts +23 -0
  209. package/components/OverlayLayout/OverlayLayout.js +184 -0
  210. package/components/OverlayLayout/OverlayLayout.js.map +1 -0
  211. package/components/OverlayLayout/icons/close.svg +13 -0
  212. package/components/OverlayLayout/icons/navigate_before.svg +16 -0
  213. package/components/OverlayLayout/index.d.ts +1 -0
  214. package/components/OverlayLayout/index.js +18 -0
  215. package/components/OverlayLayout/index.js.map +1 -0
  216. package/components/Permissions/Permissions.d.ts +7 -0
  217. package/components/Permissions/Permissions.js +54 -0
  218. package/components/Permissions/Permissions.js.map +1 -0
  219. package/components/Permissions/StyledComponents.d.ts +8 -0
  220. package/components/Permissions/StyledComponents.js +36 -0
  221. package/components/Permissions/StyledComponents.js.map +1 -0
  222. package/components/Permissions/index.d.ts +2 -0
  223. package/components/Permissions/index.js +30 -0
  224. package/components/Permissions/index.js.map +1 -0
  225. package/components/RichTextEditor/RichTextEditor.d.ts +3 -0
  226. package/components/RichTextEditor/RichTextEditor.js +30 -0
  227. package/components/RichTextEditor/RichTextEditor.js.map +1 -0
  228. package/components/RichTextEditor/index.d.ts +2 -0
  229. package/components/RichTextEditor/index.js +21 -0
  230. package/components/RichTextEditor/index.js.map +1 -0
  231. package/components/RichTextEditor/styles.scss +96 -0
  232. package/components/RichTextEditor/tools/header/index.d.ts +229 -0
  233. package/components/RichTextEditor/tools/header/index.js +731 -0
  234. package/components/RichTextEditor/tools/header/index.js.map +1 -0
  235. package/components/RichTextEditor/tools/header/styles.scss +48 -0
  236. package/components/RichTextEditor/tools/image/index.d.ts +124 -0
  237. package/components/RichTextEditor/tools/image/index.js +265 -0
  238. package/components/RichTextEditor/tools/image/index.js.map +1 -0
  239. package/components/RichTextEditor/tools/image/styles.scss +90 -0
  240. package/components/RichTextEditor/tools/image/svgs.d.ts +6 -0
  241. package/components/RichTextEditor/tools/image/svgs.js +12 -0
  242. package/components/RichTextEditor/tools/image/svgs.js.map +1 -0
  243. package/components/RichTextEditor/tools/image/tunes.d.ts +57 -0
  244. package/components/RichTextEditor/tools/image/tunes.js +146 -0
  245. package/components/RichTextEditor/tools/image/tunes.js.map +1 -0
  246. package/components/RichTextEditor/tools/image/types.d.ts +29 -0
  247. package/components/RichTextEditor/tools/image/types.js +5 -0
  248. package/components/RichTextEditor/tools/image/types.js.map +1 -0
  249. package/components/RichTextEditor/tools/image/ui.d.ts +122 -0
  250. package/components/RichTextEditor/tools/image/ui.js +301 -0
  251. package/components/RichTextEditor/tools/image/ui.js.map +1 -0
  252. package/components/RichTextEditor/tools/paragraph/index.d.ts +209 -0
  253. package/components/RichTextEditor/tools/paragraph/index.js +514 -0
  254. package/components/RichTextEditor/tools/paragraph/index.js.map +1 -0
  255. package/components/RichTextEditor/tools/paragraph/styles.scss +29 -0
  256. package/components/RichTextEditor/tools/textColor/index.d.ts +64 -0
  257. package/components/RichTextEditor/tools/textColor/index.js +271 -0
  258. package/components/RichTextEditor/tools/textColor/index.js.map +1 -0
  259. package/components/RichTextEditor/tools/textColor/styles.scss +21 -0
  260. package/components/RichTextEditor/tools/utils.d.ts +19 -0
  261. package/components/RichTextEditor/tools/utils.js +33 -0
  262. package/components/RichTextEditor/tools/utils.js.map +1 -0
  263. package/components/Routes.d.ts +6 -0
  264. package/components/Routes.js +49 -0
  265. package/components/Routes.js.map +1 -0
  266. package/components/SearchUI.d.ts +8 -0
  267. package/components/SearchUI.js +73 -0
  268. package/components/SearchUI.js.map +1 -0
  269. package/components/SimpleForm/SimpleForm.d.ts +21 -0
  270. package/components/SimpleForm/SimpleForm.js +106 -0
  271. package/components/SimpleForm/SimpleForm.js.map +1 -0
  272. package/components/SimpleForm/index.d.ts +1 -0
  273. package/components/SimpleForm/index.js +31 -0
  274. package/components/SimpleForm/index.js.map +1 -0
  275. package/components/SimpleUI/InputField.d.ts +10 -0
  276. package/components/SimpleUI/InputField.js +116 -0
  277. package/components/SimpleUI/InputField.js.map +1 -0
  278. package/components/SingleImageUpload.d.ts +55 -0
  279. package/components/SingleImageUpload.js +114 -0
  280. package/components/SingleImageUpload.js.map +1 -0
  281. package/components/SplitView/SplitView.d.ts +11 -0
  282. package/components/SplitView/SplitView.js +95 -0
  283. package/components/SplitView/SplitView.js.map +1 -0
  284. package/components/SplitView/index.d.ts +1 -0
  285. package/components/SplitView/index.js +25 -0
  286. package/components/SplitView/index.js.map +1 -0
  287. package/components/index.d.ts +1 -0
  288. package/components/index.js +13 -0
  289. package/components/index.js.map +1 -0
  290. package/hooks/useConfirmationDialog.d.ts +13 -0
  291. package/hooks/useConfirmationDialog.js +63 -0
  292. package/hooks/useConfirmationDialog.js.map +1 -0
  293. package/hooks/useDialog.d.ts +10 -0
  294. package/hooks/useDialog.js +37 -0
  295. package/hooks/useDialog.js.map +1 -0
  296. package/hooks/useSnackbar.d.ts +7 -0
  297. package/hooks/useSnackbar.js +38 -0
  298. package/hooks/useSnackbar.js.map +1 -0
  299. package/index.d.ts +35 -0
  300. package/index.js +373 -0
  301. package/index.js.map +1 -0
  302. package/package.json +102 -0
  303. package/plugins/FileManagerFileTypePlugin.d.ts +33 -0
  304. package/plugins/FileManagerFileTypePlugin.js +63 -0
  305. package/plugins/FileManagerFileTypePlugin.js.map +1 -0
  306. package/plugins/MenuPlugin.d.ts +37 -0
  307. package/plugins/MenuPlugin.js +58 -0
  308. package/plugins/MenuPlugin.js.map +1 -0
  309. package/plugins/PermissionRendererPlugin.d.ts +22 -0
  310. package/plugins/PermissionRendererPlugin.js +58 -0
  311. package/plugins/PermissionRendererPlugin.js.map +1 -0
  312. package/plugins/fileManager/fileDefault.d.ts +2 -0
  313. package/plugins/fileManager/fileDefault.js +34 -0
  314. package/plugins/fileManager/fileDefault.js.map +1 -0
  315. package/plugins/fileManager/fileImage/DeleteAction.d.ts +7 -0
  316. package/plugins/fileManager/fileImage/DeleteAction.js +83 -0
  317. package/plugins/fileManager/fileImage/DeleteAction.js.map +1 -0
  318. package/plugins/fileManager/fileImage/EditAction.d.ts +10 -0
  319. package/plugins/fileManager/fileImage/EditAction.js +179 -0
  320. package/plugins/fileManager/fileImage/EditAction.js.map +1 -0
  321. package/plugins/fileManager/fileImage/index.d.ts +2 -0
  322. package/plugins/fileManager/fileImage/index.js +46 -0
  323. package/plugins/fileManager/fileImage/index.js.map +1 -0
  324. package/plugins/fileManager/icons/edit.svg +17 -0
  325. package/plugins/fileManager/icons/round-description-24px.svg +1 -0
  326. package/plugins/fileManager/index.d.ts +2 -0
  327. package/plugins/fileManager/index.js +21 -0
  328. package/plugins/fileManager/index.js.map +1 -0
  329. package/plugins/globalSearch/SearchBar.d.ts +15 -0
  330. package/plugins/globalSearch/SearchBar.js +273 -0
  331. package/plugins/globalSearch/SearchBar.js.map +1 -0
  332. package/plugins/globalSearch/SearchBarDropdown.d.ts +23 -0
  333. package/plugins/globalSearch/SearchBarDropdown.js +101 -0
  334. package/plugins/globalSearch/SearchBarDropdown.js.map +1 -0
  335. package/plugins/globalSearch/icons/round-search-24px.svg +20 -0
  336. package/plugins/globalSearch/index.d.ts +7 -0
  337. package/plugins/globalSearch/index.js +16 -0
  338. package/plugins/globalSearch/index.js.map +1 -0
  339. package/plugins/globalSearch/styled.d.ts +11 -0
  340. package/plugins/globalSearch/styled.js +135 -0
  341. package/plugins/globalSearch/styled.js.map +1 -0
  342. package/plugins/uiLayoutRenderer/index.d.ts +2 -0
  343. package/plugins/uiLayoutRenderer/index.js +75 -0
  344. package/plugins/uiLayoutRenderer/index.js.map +1 -0
  345. package/styles/material-theme-assignments.scss +350 -0
  346. package/styles/material.scss +43 -0
  347. package/styles/theme.scss +46 -0
  348. package/styles.scss +2 -0
  349. package/types.d.ts +93 -0
  350. package/types.js +5 -0
  351. package/types.js.map +1 -0
  352. package/ui/UIElement.d.ts +2 -0
  353. package/ui/UIElement.js +19 -0
  354. package/ui/UIElement.js.map +1 -0
  355. package/ui/UILayout.d.ts +1 -0
  356. package/ui/UILayout.js +19 -0
  357. package/ui/UILayout.js.map +1 -0
  358. package/ui/UIRenderer.d.ts +2 -0
  359. package/ui/UIRenderer.js +13 -0
  360. package/ui/UIRenderer.js.map +1 -0
  361. package/ui/UIView.d.ts +2 -0
  362. package/ui/UIView.js +25 -0
  363. package/ui/UIView.js.map +1 -0
  364. package/ui/elements/AccordionElement.d.ts +27 -0
  365. package/ui/elements/AccordionElement.js +110 -0
  366. package/ui/elements/AccordionElement.js.map +1 -0
  367. package/ui/elements/ButtonElement.d.ts +24 -0
  368. package/ui/elements/ButtonElement.js +105 -0
  369. package/ui/elements/ButtonElement.js.map +1 -0
  370. package/ui/elements/ButtonGroupElement.d.ts +6 -0
  371. package/ui/elements/ButtonGroupElement.js +67 -0
  372. package/ui/elements/ButtonGroupElement.js.map +1 -0
  373. package/ui/elements/GenericElement.d.ts +1 -0
  374. package/ui/elements/GenericElement.js +18 -0
  375. package/ui/elements/GenericElement.js.map +1 -0
  376. package/ui/elements/LabelElement.d.ts +16 -0
  377. package/ui/elements/LabelElement.js +60 -0
  378. package/ui/elements/LabelElement.js.map +1 -0
  379. package/ui/elements/NavigationMenuElement.d.ts +33 -0
  380. package/ui/elements/NavigationMenuElement.js +177 -0
  381. package/ui/elements/NavigationMenuElement.js.map +1 -0
  382. package/ui/elements/PanelElement.d.ts +3 -0
  383. package/ui/elements/PanelElement.js +33 -0
  384. package/ui/elements/PanelElement.js.map +1 -0
  385. package/ui/elements/PlaceholderElement.d.ts +6 -0
  386. package/ui/elements/PlaceholderElement.js +44 -0
  387. package/ui/elements/PlaceholderElement.js.map +1 -0
  388. package/ui/elements/SmallButtonElement.d.ts +6 -0
  389. package/ui/elements/SmallButtonElement.js +64 -0
  390. package/ui/elements/SmallButtonElement.js.map +1 -0
  391. package/ui/elements/TypographyElement.d.ts +13 -0
  392. package/ui/elements/TypographyElement.js +67 -0
  393. package/ui/elements/TypographyElement.js.map +1 -0
  394. package/ui/elements/ViewElement.d.ts +1 -0
  395. package/ui/elements/ViewElement.js +18 -0
  396. package/ui/elements/ViewElement.js.map +1 -0
  397. package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.d.ts +6 -0
  398. package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.js +60 -0
  399. package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.js.map +1 -0
  400. package/ui/elements/form/DynamicFieldsetElement.d.ts +43 -0
  401. package/ui/elements/form/DynamicFieldsetElement.js +158 -0
  402. package/ui/elements/form/DynamicFieldsetElement.js.map +1 -0
  403. package/ui/elements/form/FileManagerElement/EmptyStateElement.d.ts +4 -0
  404. package/ui/elements/form/FileManagerElement/EmptyStateElement.js +41 -0
  405. package/ui/elements/form/FileManagerElement/EmptyStateElement.js.map +1 -0
  406. package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.d.ts +7 -0
  407. package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.js +95 -0
  408. package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.js.map +1 -0
  409. package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.d.ts +13 -0
  410. package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.js +123 -0
  411. package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.js.map +1 -0
  412. package/ui/elements/form/FileManagerElement/styled.d.ts +20 -0
  413. package/ui/elements/form/FileManagerElement/styled.js +120 -0
  414. package/ui/elements/form/FileManagerElement/styled.js.map +1 -0
  415. package/ui/elements/form/FileManagerElement.d.ts +24 -0
  416. package/ui/elements/form/FileManagerElement.js +108 -0
  417. package/ui/elements/form/FileManagerElement.js.map +1 -0
  418. package/ui/elements/form/FormElement.d.ts +21 -0
  419. package/ui/elements/form/FormElement.js +66 -0
  420. package/ui/elements/form/FormElement.js.map +1 -0
  421. package/ui/elements/form/FormFieldElement.d.ts +56 -0
  422. package/ui/elements/form/FormFieldElement.js +206 -0
  423. package/ui/elements/form/FormFieldElement.js.map +1 -0
  424. package/ui/elements/form/HiddenElement.d.ts +6 -0
  425. package/ui/elements/form/HiddenElement.js +64 -0
  426. package/ui/elements/form/HiddenElement.js.map +1 -0
  427. package/ui/elements/form/InputElement.d.ts +7 -0
  428. package/ui/elements/form/InputElement.js +72 -0
  429. package/ui/elements/form/InputElement.js.map +1 -0
  430. package/ui/elements/form/PasswordElement.d.ts +6 -0
  431. package/ui/elements/form/PasswordElement.js +66 -0
  432. package/ui/elements/form/PasswordElement.js.map +1 -0
  433. package/ui/elements/form/README.md +2 -0
  434. package/ui/elements/form/SelectElement.d.ts +15 -0
  435. package/ui/elements/form/SelectElement.js +87 -0
  436. package/ui/elements/form/SelectElement.js.map +1 -0
  437. package/ui/elements/form/TextareaElement.d.ts +15 -0
  438. package/ui/elements/form/TextareaElement.js +72 -0
  439. package/ui/elements/form/TextareaElement.js.map +1 -0
  440. package/ui/views/AdminView/ContentElement.d.ts +4 -0
  441. package/ui/views/AdminView/ContentElement.js +78 -0
  442. package/ui/views/AdminView/ContentElement.js.map +1 -0
  443. package/ui/views/AdminView/HeaderElement.d.ts +13 -0
  444. package/ui/views/AdminView/HeaderElement.js +144 -0
  445. package/ui/views/AdminView/HeaderElement.js.map +1 -0
  446. package/ui/views/AdminView/HeaderSectionCenterElement.d.ts +6 -0
  447. package/ui/views/AdminView/HeaderSectionCenterElement.js +62 -0
  448. package/ui/views/AdminView/HeaderSectionCenterElement.js.map +1 -0
  449. package/ui/views/AdminView/HeaderSectionLeftElement.d.ts +6 -0
  450. package/ui/views/AdminView/HeaderSectionLeftElement.js +62 -0
  451. package/ui/views/AdminView/HeaderSectionLeftElement.js.map +1 -0
  452. package/ui/views/AdminView/HeaderSectionRightElement.d.ts +6 -0
  453. package/ui/views/AdminView/HeaderSectionRightElement.js +62 -0
  454. package/ui/views/AdminView/HeaderSectionRightElement.js.map +1 -0
  455. package/ui/views/AdminView/components/Dialog.d.ts +2 -0
  456. package/ui/views/AdminView/components/Dialog.js +57 -0
  457. package/ui/views/AdminView/components/Dialog.js.map +1 -0
  458. package/ui/views/AdminView/components/Hamburger.d.ts +3 -0
  459. package/ui/views/AdminView/components/Hamburger.js +39 -0
  460. package/ui/views/AdminView/components/Hamburger.js.map +1 -0
  461. package/ui/views/AdminView/components/Snackbar.d.ts +3 -0
  462. package/ui/views/AdminView/components/Snackbar.js +41 -0
  463. package/ui/views/AdminView/components/Snackbar.js.map +1 -0
  464. package/ui/views/FormView/FormContainerElement.d.ts +12 -0
  465. package/ui/views/FormView/FormContainerElement.js +71 -0
  466. package/ui/views/FormView/FormContainerElement.js.map +1 -0
  467. package/ui/views/FormView/FormContentElement.d.ts +3 -0
  468. package/ui/views/FormView/FormContentElement.js +33 -0
  469. package/ui/views/FormView/FormContentElement.js.map +1 -0
  470. package/ui/views/FormView/FormFooterElement.d.ts +6 -0
  471. package/ui/views/FormView/FormFooterElement.js +68 -0
  472. package/ui/views/FormView/FormFooterElement.js.map +1 -0
  473. package/ui/views/FormView/FormHeaderElement.d.ts +14 -0
  474. package/ui/views/FormView/FormHeaderElement.js +103 -0
  475. package/ui/views/FormView/FormHeaderElement.js.map +1 -0
  476. package/ui/views/FormView.d.ts +40 -0
  477. package/ui/views/FormView.js +208 -0
  478. package/ui/views/FormView.js.map +1 -0
  479. package/ui/views/OverlayView/ContentElement.d.ts +6 -0
  480. package/ui/views/OverlayView/ContentElement.js +61 -0
  481. package/ui/views/OverlayView/ContentElement.js.map +1 -0
  482. package/ui/views/OverlayView/HeaderElement.d.ts +24 -0
  483. package/ui/views/OverlayView/HeaderElement.js +134 -0
  484. package/ui/views/OverlayView/HeaderElement.js.map +1 -0
  485. package/ui/views/OverlayView/HeaderTitleElement.d.ts +13 -0
  486. package/ui/views/OverlayView/HeaderTitleElement.js +73 -0
  487. package/ui/views/OverlayView/HeaderTitleElement.js.map +1 -0
  488. package/ui/views/OverlayView/useOverlayView.d.ts +5 -0
  489. package/ui/views/OverlayView/useOverlayView.js +54 -0
  490. package/ui/views/OverlayView/useOverlayView.js.map +1 -0
  491. package/ui/views/OverlayView.d.ts +29 -0
  492. package/ui/views/OverlayView.js +199 -0
  493. package/ui/views/OverlayView.js.map +1 -0
  494. package/ui/views/SplitView/SplitViewPanelElement.d.ts +11 -0
  495. package/ui/views/SplitView/SplitViewPanelElement.js +91 -0
  496. package/ui/views/SplitView/SplitViewPanelElement.js.map +1 -0
  497. package/ui/views/SplitView.d.ts +21 -0
  498. package/ui/views/SplitView.js +162 -0
  499. package/ui/views/SplitView.js.map +1 -0
@@ -0,0 +1,339 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.tagWithoutScopePrefix = exports.formatTagAsLabel = exports.default = void 0;
11
+
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+
14
+ var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
15
+
16
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
17
+
18
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
19
+
20
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
21
+
22
+ var _react = _interopRequireWildcard(require("react"));
23
+
24
+ var _classnames = _interopRequireDefault(require("classnames"));
25
+
26
+ var _emotion = require("emotion");
27
+
28
+ var _reactHooks = require("@apollo/react-hooks");
29
+
30
+ var _set = _interopRequireDefault(require("lodash/set"));
31
+
32
+ var _get = _interopRequireDefault(require("lodash/get"));
33
+
34
+ var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
35
+
36
+ var _Chips = require("@webiny/ui/Chips");
37
+
38
+ var _Button = require("@webiny/ui/Button");
39
+
40
+ var _AutoComplete = require("@webiny/ui/AutoComplete");
41
+
42
+ var _Icon = require("@webiny/ui/Icon");
43
+
44
+ var _form = require("@webiny/form");
45
+
46
+ var _useSnackbar2 = require("../../../hooks/useSnackbar");
47
+
48
+ var _FileManagerContext = require("./../FileManagerContext");
49
+
50
+ var _graphql = require("./../graphql");
51
+
52
+ var _roundEdit24px = require("./../icons/round-edit-24px.svg");
53
+
54
+ var _roundLabel24px = require("./../icons/round-label-24px.svg");
55
+
56
+ var _excluded = ["value"];
57
+ var SCOPE_SEPARATOR = ":";
58
+
59
+ var formatTagAsLabel = function formatTagAsLabel(tag, scope) {
60
+ if (!scope) {
61
+ return tag;
62
+ }
63
+
64
+ return tag.replace("".concat(scope).concat(SCOPE_SEPARATOR), "");
65
+ };
66
+
67
+ exports.formatTagAsLabel = formatTagAsLabel;
68
+
69
+ var tagWithoutScopePrefix = function tagWithoutScopePrefix(tags, scope) {
70
+ return tags.filter(function (tag) {
71
+ return tag !== scope;
72
+ }).map(function (tag) {
73
+ return formatTagAsLabel(tag, scope);
74
+ });
75
+ };
76
+
77
+ exports.tagWithoutScopePrefix = tagWithoutScopePrefix;
78
+ var chipsStyle = /*#__PURE__*/(0, _emotion.css)({
79
+ "&.mdc-chip-set": {
80
+ padding: 0,
81
+ marginLeft: -4,
82
+ "& .mdc-chip": {
83
+ backgroundColor: "var(--mdc-theme-background)"
84
+ }
85
+ }
86
+ }, "label:chipsStyle;");
87
+ var iconButtonStyle = /*#__PURE__*/(0, _emotion.css)({
88
+ "&.mdc-icon-button svg": {
89
+ width: 20,
90
+ height: 20
91
+ }
92
+ }, "label:iconButtonStyle;");
93
+ var addTagsStyle = /*#__PURE__*/(0, _emotion.css)({
94
+ "&.mdc-button:not(:disabled)": {
95
+ color: "var(--mdc-theme-text-secondary-on-background)",
96
+ textTransform: "capitalize",
97
+ letterSpacing: "initial",
98
+ marginLeft: -8
99
+ }
100
+ }, "label:addTagsStyle;");
101
+ var actionWrapperStyle = /*#__PURE__*/(0, _emotion.css)({
102
+ marginTop: 16,
103
+ "& button:first-child": {
104
+ marginRight: 16
105
+ }
106
+ }, "label:actionWrapperStyle;");
107
+
108
+ var Tags = function Tags(_ref) {
109
+ var file = _ref.file,
110
+ canEdit = _ref.canEdit;
111
+ var client = (0, _reactHooks.useApolloClient)();
112
+
113
+ var _useState = (0, _react.useState)(false),
114
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
115
+ editing = _useState2[0],
116
+ setEdit = _useState2[1];
117
+
118
+ var _useState3 = (0, _react.useState)(false),
119
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
120
+ saving = _useState4[0],
121
+ setSaving = _useState4[1];
122
+
123
+ var _useState5 = (0, _react.useState)(Array.isArray(file.tags) ? (0, _toConsumableArray2.default)(file.tags) : []),
124
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
125
+ initialTags = _useState6[0],
126
+ setInitialTags = _useState6[1];
127
+
128
+ var _useSnackbar = (0, _useSnackbar2.useSnackbar)(),
129
+ showSnackbar = _useSnackbar.showSnackbar;
130
+
131
+ var _useFileManager = (0, _FileManagerContext.useFileManager)(),
132
+ queryParams = _useFileManager.queryParams;
133
+
134
+ var handleEdit = (0, _react.useCallback)(function () {
135
+ return setEdit(true);
136
+ }, []);
137
+ var listTagsQuery = (0, _reactHooks.useQuery)(_graphql.LIST_TAGS, {
138
+ variables: {
139
+ where: (0, _FileManagerContext.getWhere)(queryParams.scope)
140
+ }
141
+ });
142
+ var listTags = (0, _get.default)(listTagsQuery, "data.fileManager.listTags", []);
143
+ var allTags = tagWithoutScopePrefix(listTags, queryParams.scope);
144
+ var isEditingAllowed = canEdit(file);
145
+ var renderHeaderContent = (0, _react.useCallback)(function (_ref2) {
146
+ var data = _ref2.data;
147
+
148
+ if (editing) {
149
+ return null;
150
+ }
151
+
152
+ var hasTags = data.tags.length > 0;
153
+
154
+ if (hasTags) {
155
+ // Render existing tags and "edit tags" action.
156
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Chips.Chips, {
157
+ className: (0, _classnames.default)("list-item__content", chipsStyle)
158
+ }, data.tags.filter(function (tag) {
159
+ return tag !== queryParams.scope;
160
+ }).map(function (tag, index) {
161
+ var label = typeof tag === "string" ? tag : tag.name;
162
+ return /*#__PURE__*/_react.default.createElement(_Chips.Chip, {
163
+ key: label + index,
164
+ label: formatTagAsLabel(label, queryParams.scope)
165
+ });
166
+ })), isEditingAllowed && /*#__PURE__*/_react.default.createElement(_Button.IconButton, {
167
+ className: iconButtonStyle,
168
+ icon: /*#__PURE__*/_react.default.createElement(_roundEdit24px.ReactComponent, null),
169
+ onClick: handleEdit
170
+ }));
171
+ } // Render "add tags" action.
172
+
173
+
174
+ return /*#__PURE__*/_react.default.createElement(_Button.ButtonDefault, {
175
+ className: addTagsStyle,
176
+ onClick: handleEdit,
177
+ disabled: !isEditingAllowed,
178
+ "data-testid": "fm.tags.add"
179
+ }, "Add tags...");
180
+ }, [editing, isEditingAllowed]);
181
+ return /*#__PURE__*/_react.default.createElement(_form.Form, {
182
+ data: {
183
+ tags: initialTags
184
+ },
185
+ onSubmit: /*#__PURE__*/function () {
186
+ var _ref4 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(_ref3) {
187
+ var tags;
188
+ return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
189
+ while (1) {
190
+ switch (_context.prev = _context.next) {
191
+ case 0:
192
+ tags = _ref3.tags;
193
+ setSaving(true);
194
+ client.mutate({
195
+ mutation: _graphql.UPDATE_FILE,
196
+ variables: {
197
+ id: file.id,
198
+ data: {
199
+ tags: tags
200
+ }
201
+ },
202
+ update: function update(cache, updated) {
203
+ var newFileData = (0, _get.default)(updated, "data.fileManager.updateFile.data"); // 1. Update files list cache
204
+
205
+ var data = (0, _cloneDeep.default)(cache.readQuery({
206
+ query: _graphql.LIST_FILES,
207
+ variables: queryParams
208
+ }));
209
+
210
+ if (data) {
211
+ data.fileManager.listFiles.data.forEach(function (item) {
212
+ if (item.key === newFileData.key) {
213
+ item.tags = newFileData.tags;
214
+ }
215
+ });
216
+ }
217
+
218
+ cache.writeQuery({
219
+ query: _graphql.LIST_FILES,
220
+ variables: queryParams,
221
+ data: data
222
+ }); // 2. Update "LIST_TAGS" cache
223
+
224
+ if (Array.isArray(newFileData.tags)) {
225
+ // Get list tags data
226
+ var listTagsData = (0, _cloneDeep.default)(cache.readQuery({
227
+ query: _graphql.LIST_TAGS,
228
+ variables: {
229
+ where: (0, _FileManagerContext.getWhere)(queryParams.scope)
230
+ }
231
+ }));
232
+
233
+ if (!listTagsData) {
234
+ return;
235
+ } // Add new tag in list
236
+
237
+
238
+ var updatedTagsList = (0, _toConsumableArray2.default)(newFileData.tags);
239
+
240
+ if (Array.isArray(listTagsData.fileManager.listTags)) {
241
+ listTagsData.fileManager.listTags.forEach(function (tag) {
242
+ if (!updatedTagsList.includes(tag)) {
243
+ updatedTagsList.push(tag);
244
+ }
245
+ });
246
+ }
247
+
248
+ (0, _set.default)(listTagsData, "fileManager.listTags", updatedTagsList); // Write it to cache
249
+
250
+ cache.writeQuery({
251
+ query: _graphql.LIST_TAGS,
252
+ variables: {
253
+ where: (0, _FileManagerContext.getWhere)(queryParams.scope)
254
+ },
255
+ data: listTagsData
256
+ });
257
+ }
258
+ }
259
+ }).then(function () {
260
+ setInitialTags(tags);
261
+ setSaving(false);
262
+ setEdit(false);
263
+ showSnackbar("Tags successfully updated.");
264
+ });
265
+
266
+ case 3:
267
+ case "end":
268
+ return _context.stop();
269
+ }
270
+ }
271
+ }, _callee);
272
+ }));
273
+
274
+ return function (_x) {
275
+ return _ref4.apply(this, arguments);
276
+ };
277
+ }()
278
+ }, function (_ref5) {
279
+ var Bind = _ref5.Bind,
280
+ data = _ref5.data,
281
+ setValue = _ref5.setValue,
282
+ submit = _ref5.submit;
283
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("li-title", null, /*#__PURE__*/_react.default.createElement(_Icon.Icon, {
284
+ className: "list-item__icon",
285
+ icon: /*#__PURE__*/_react.default.createElement(_roundLabel24px.ReactComponent, null)
286
+ }), renderHeaderContent({
287
+ // TODO @ts-refactor
288
+ // @ts-ignore
289
+ data: data
290
+ })), editing && /*#__PURE__*/_react.default.createElement("li-content", null, /*#__PURE__*/_react.default.createElement(Bind, {
291
+ name: "tags",
292
+ beforeChange: function beforeChange(tags, baseOnChange) {
293
+ var formattedTags = tags.map(function (tag) {
294
+ var tagInLowerCase = tag.toLowerCase();
295
+ /**
296
+ * If "scope" exists, prefix tag with "scope" if not already.
297
+ */
298
+
299
+ if (queryParams.scope && !tagInLowerCase.startsWith(queryParams.scope)) {
300
+ return "".concat(queryParams.scope).concat(SCOPE_SEPARATOR).concat(tagInLowerCase);
301
+ }
302
+
303
+ return tagInLowerCase;
304
+ });
305
+ baseOnChange(formattedTags);
306
+ }
307
+ }, function (_ref6) {
308
+ var value = _ref6.value,
309
+ bindProps = (0, _objectWithoutProperties2.default)(_ref6, _excluded);
310
+ return /*#__PURE__*/_react.default.createElement(_AutoComplete.MultiAutoComplete, Object.assign({}, bindProps, {
311
+ value: tagWithoutScopePrefix(value, queryParams.scope),
312
+ options: allTags,
313
+ placeholder: "homepage asset",
314
+ description: "Type in a new tag or select an existing one.",
315
+ unique: true,
316
+ allowFreeInput: true,
317
+ useSimpleValues: true,
318
+ disabled: saving
319
+ }));
320
+ }), /*#__PURE__*/_react.default.createElement("div", {
321
+ className: actionWrapperStyle
322
+ }, /*#__PURE__*/_react.default.createElement(_Button.ButtonPrimary, {
323
+ small: true,
324
+ onClick: function onClick(ev) {
325
+ submit(ev);
326
+ },
327
+ "data-testid": "fm.tags.submit"
328
+ }, "Submit"), /*#__PURE__*/_react.default.createElement(_Button.ButtonSecondary, {
329
+ small: true,
330
+ onClick: function onClick() {
331
+ setValue("tags", initialTags);
332
+ setEdit(false);
333
+ }
334
+ }, "Cancel"))));
335
+ });
336
+ };
337
+
338
+ var _default = Tags;
339
+ exports.default = _default;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["SCOPE_SEPARATOR","formatTagAsLabel","tag","scope","replace","tagWithoutScopePrefix","tags","filter","map","chipsStyle","css","padding","marginLeft","backgroundColor","iconButtonStyle","width","height","addTagsStyle","color","textTransform","letterSpacing","actionWrapperStyle","marginTop","marginRight","Tags","file","canEdit","client","useApolloClient","useState","editing","setEdit","saving","setSaving","Array","isArray","initialTags","setInitialTags","useSnackbar","showSnackbar","useFileManager","queryParams","handleEdit","useCallback","listTagsQuery","useQuery","LIST_TAGS","variables","where","getWhere","listTags","get","allTags","isEditingAllowed","renderHeaderContent","data","hasTags","length","classNames","index","label","name","mutate","mutation","UPDATE_FILE","id","update","cache","updated","newFileData","cloneDeep","readQuery","query","LIST_FILES","fileManager","listFiles","forEach","item","key","writeQuery","listTagsData","updatedTagsList","includes","push","set","then","Bind","setValue","submit","baseOnChange","formattedTags","tagInLowerCase","toLowerCase","startsWith","value","bindProps","ev"],"sources":["Tags.tsx"],"sourcesContent":["import React, { useCallback, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { css } from \"emotion\";\nimport { useApolloClient, useQuery } from \"@apollo/react-hooks\";\nimport set from \"lodash/set\";\nimport get from \"lodash/get\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport { Chips, Chip } from \"@webiny/ui/Chips\";\nimport { ButtonSecondary, ButtonPrimary, ButtonDefault, IconButton } from \"@webiny/ui/Button\";\nimport { MultiAutoComplete } from \"@webiny/ui/AutoComplete\";\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { Form } from \"@webiny/form\";\nimport { useSnackbar } from \"~/hooks/useSnackbar\";\nimport { getWhere, useFileManager } from \"./../FileManagerContext\";\nimport {\n UPDATE_FILE,\n LIST_FILES,\n LIST_TAGS,\n ListFilesQueryResponse,\n ListFileTagsQueryResponse\n} from \"./../graphql\";\nimport { ReactComponent as EditIcon } from \"./../icons/round-edit-24px.svg\";\nimport { ReactComponent as LabelIcon } from \"./../icons/round-label-24px.svg\";\nimport { FileItem } from \"../types\";\n\nconst SCOPE_SEPARATOR = \":\";\n\nexport const formatTagAsLabel = (tag: string, scope: string | undefined) => {\n if (!scope) {\n return tag;\n }\n return tag.replace(`${scope}${SCOPE_SEPARATOR}`, \"\");\n};\n\nexport const tagWithoutScopePrefix = (tags: string[], scope: string) => {\n return tags.filter(tag => tag !== scope).map(tag => formatTagAsLabel(tag, scope));\n};\n\nconst chipsStyle = css({\n \"&.mdc-chip-set\": {\n padding: 0,\n marginLeft: -4,\n \"& .mdc-chip\": {\n backgroundColor: \"var(--mdc-theme-background)\"\n }\n }\n});\nconst iconButtonStyle = css({\n \"&.mdc-icon-button svg\": {\n width: 20,\n height: 20\n }\n});\nconst addTagsStyle = css({\n \"&.mdc-button:not(:disabled)\": {\n color: \"var(--mdc-theme-text-secondary-on-background)\",\n textTransform: \"capitalize\",\n letterSpacing: \"initial\",\n marginLeft: -8\n }\n});\nconst actionWrapperStyle = css({\n marginTop: 16,\n \"& button:first-child\": {\n marginRight: 16\n }\n});\n\ninterface TagsProps {\n file: FileItem;\n canEdit: (file: FileItem) => boolean;\n}\n\nconst Tags: React.FC<TagsProps> = ({ file, canEdit }) => {\n const client = useApolloClient();\n\n const [editing, setEdit] = useState(false);\n const [saving, setSaving] = useState(false);\n const [initialTags, setInitialTags] = useState(Array.isArray(file.tags) ? [...file.tags] : []);\n const { showSnackbar } = useSnackbar();\n const { queryParams } = useFileManager();\n const handleEdit = useCallback(() => setEdit(true), []);\n const listTagsQuery = useQuery(LIST_TAGS, {\n variables: { where: getWhere(queryParams.scope) }\n });\n const listTags = get(listTagsQuery, \"data.fileManager.listTags\", []);\n const allTags = tagWithoutScopePrefix(listTags, queryParams.scope);\n\n const isEditingAllowed = canEdit(file);\n\n const renderHeaderContent = useCallback(\n ({ data }: { data: { tags: { name: string }[] } }) => {\n if (editing) {\n return null;\n }\n const hasTags = data.tags.length > 0;\n\n if (hasTags) {\n // Render existing tags and \"edit tags\" action.\n return (\n <>\n <Chips className={classNames(\"list-item__content\", chipsStyle)}>\n {data.tags\n .filter(tag => tag !== queryParams.scope)\n .map((tag, index) => {\n const label = typeof tag === \"string\" ? tag : tag.name;\n return (\n <Chip\n key={label + index}\n label={formatTagAsLabel(label, queryParams.scope)}\n />\n );\n })}\n </Chips>\n {isEditingAllowed && (\n <IconButton\n className={iconButtonStyle}\n icon={<EditIcon />}\n onClick={handleEdit}\n />\n )}\n </>\n );\n }\n // Render \"add tags\" action.\n return (\n <ButtonDefault\n className={addTagsStyle}\n onClick={handleEdit}\n disabled={!isEditingAllowed}\n data-testid=\"fm.tags.add\"\n >\n Add tags...\n </ButtonDefault>\n );\n },\n [editing, isEditingAllowed]\n );\n\n return (\n <Form\n data={{\n tags: initialTags\n }}\n onSubmit={async ({ tags }) => {\n setSaving(true);\n client\n .mutate({\n mutation: UPDATE_FILE,\n variables: {\n id: file.id,\n data: { tags }\n },\n update: (cache, updated) => {\n const newFileData: FileItem = get(\n updated,\n \"data.fileManager.updateFile.data\"\n );\n\n // 1. Update files list cache\n const data = cloneDeep(\n cache.readQuery<ListFilesQueryResponse>({\n query: LIST_FILES,\n variables: queryParams\n })\n );\n\n if (data) {\n data.fileManager.listFiles.data.forEach(item => {\n if (item.key === newFileData.key) {\n item.tags = newFileData.tags;\n }\n });\n }\n\n cache.writeQuery({\n query: LIST_FILES,\n variables: queryParams,\n data\n });\n // 2. Update \"LIST_TAGS\" cache\n if (Array.isArray(newFileData.tags)) {\n // Get list tags data\n const listTagsData = cloneDeep(\n cache.readQuery<ListFileTagsQueryResponse>({\n query: LIST_TAGS,\n variables: { where: getWhere(queryParams.scope) }\n })\n );\n if (!listTagsData) {\n return;\n }\n // Add new tag in list\n const updatedTagsList = [...newFileData.tags];\n\n if (Array.isArray(listTagsData.fileManager.listTags)) {\n listTagsData.fileManager.listTags.forEach(tag => {\n if (!updatedTagsList.includes(tag)) {\n updatedTagsList.push(tag);\n }\n });\n }\n\n set(listTagsData, \"fileManager.listTags\", updatedTagsList);\n // Write it to cache\n cache.writeQuery({\n query: LIST_TAGS,\n variables: { where: getWhere(queryParams.scope) },\n data: listTagsData\n });\n }\n }\n })\n .then(() => {\n setInitialTags(tags);\n setSaving(false);\n setEdit(false);\n showSnackbar(\"Tags successfully updated.\");\n });\n }}\n >\n {({ Bind, data, setValue, submit }) => (\n <React.Fragment>\n <li-title>\n <Icon className={\"list-item__icon\"} icon={<LabelIcon />} />\n {renderHeaderContent({\n // TODO @ts-refactor\n // @ts-ignore\n data\n })}\n </li-title>\n {editing && (\n <li-content>\n <Bind\n name={\"tags\"}\n beforeChange={(\n tags: string[],\n baseOnChange: (tags: string[]) => void\n ) => {\n const formattedTags = tags.map(tag => {\n const tagInLowerCase = tag.toLowerCase();\n /**\n * If \"scope\" exists, prefix tag with \"scope\" if not already.\n */\n if (\n queryParams.scope &&\n !tagInLowerCase.startsWith(queryParams.scope)\n ) {\n return `${queryParams.scope}${SCOPE_SEPARATOR}${tagInLowerCase}`;\n }\n return tagInLowerCase;\n });\n baseOnChange(formattedTags);\n }}\n >\n {({ value, ...bindProps }) => (\n <MultiAutoComplete\n {...bindProps}\n value={tagWithoutScopePrefix(value, queryParams.scope)}\n options={allTags}\n placeholder={\"homepage asset\"}\n description={\"Type in a new tag or select an existing one.\"}\n unique={true}\n allowFreeInput={true}\n useSimpleValues={true}\n disabled={saving}\n />\n )}\n </Bind>\n <div className={actionWrapperStyle}>\n <ButtonPrimary\n small\n onClick={ev => {\n submit(ev);\n }}\n data-testid={\"fm.tags.submit\"}\n >\n Submit\n </ButtonPrimary>\n <ButtonSecondary\n small\n onClick={() => {\n setValue(\"tags\", initialTags);\n setEdit(false);\n }}\n >\n Cancel\n </ButtonSecondary>\n </div>\n </li-content>\n )}\n </React.Fragment>\n )}\n </Form>\n );\n};\n\nexport default Tags;\n"],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import React from "react";
2
+ import { FileItem } from "./types";
3
+ import { FilesRenderChildren } from "react-butterfiles";
4
+ declare global {
5
+ namespace JSX {
6
+ interface IntrinsicElements {
7
+ "li-title": {
8
+ children?: React.ReactNode;
9
+ };
10
+ "li-content": {
11
+ children?: React.ReactNode;
12
+ };
13
+ }
14
+ }
15
+ }
16
+ interface FileDetailsProps {
17
+ canEdit: (item: any) => boolean;
18
+ file: FileItem;
19
+ uploadFile: (files: FileItem[] | FileItem) => Promise<number | null>;
20
+ validateFiles: FilesRenderChildren["validateFiles"];
21
+ [key: string]: any;
22
+ }
23
+ declare const FileDetails: React.FC<FileDetailsProps>;
24
+ export default FileDetails;