@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.
- package/LICENSE +21 -0
- package/README.md +21 -0
- package/assets/icons/add-18px.svg +3 -0
- package/assets/icons/arrow_drop_down-24px.svg +4 -0
- package/assets/icons/attach_file_black_24dp.svg +1 -0
- package/assets/icons/baseline-menu-24px.svg +4 -0
- package/assets/icons/baseline-notification_important-24px.svg +4 -0
- package/assets/icons/baseline-security-24px.svg +4 -0
- package/assets/icons/filter-24px.svg +8 -0
- package/assets/icons/github-brands.svg +1 -0
- package/assets/icons/highlight-24px.svg +1 -0
- package/assets/icons/icon-community.svg +16 -0
- package/assets/icons/icon-documentation.svg +16 -0
- package/assets/icons/info.svg +1 -0
- package/assets/icons/insert_drive_file-24px.svg +1 -0
- package/assets/icons/insert_photo-24px.svg +1 -0
- package/assets/icons/label-24px.svg +1 -0
- package/assets/icons/round-account_circle-24px.svg +1 -0
- package/assets/icons/round-add-24px.svg +16 -0
- package/assets/icons/round-arrow_drop_down-24px.svg +1 -0
- package/assets/icons/round-chevron_right-24px.svg +12 -0
- package/assets/icons/round-feedback-24px.svg +54 -0
- package/assets/icons/round-help-24px.svg +1 -0
- package/assets/icons/round-invert_colors-24px.svg +52 -0
- package/assets/icons/round-keyboard_arrow_down-24px.svg +16 -0
- package/assets/icons/round-keyboard_arrow_up-24px.svg +16 -0
- package/assets/icons/round-lock_open-24px.svg +60 -0
- package/assets/icons/round-more_vert-24px.svg +12 -0
- package/assets/icons/round-open_in_new-24px.svg +44 -0
- package/assets/icons/round-settings-24px.svg +4 -0
- package/assets/icons/search-24px.svg +20 -0
- package/assets/icons/slack-logo.svg +1 -0
- package/assets/icons/today-24px.svg +1 -0
- package/assets/icons/touch_app.svg +1 -0
- package/assets/images/arr.png +0 -0
- package/assets/images/arr_2.png +0 -0
- package/assets/images/header_bg.jpg +0 -0
- package/assets/images/icons.png +0 -0
- package/assets/images/icons_retina.png +0 -0
- package/assets/images/logo.png +0 -0
- package/assets/images/logo_orange.png +0 -0
- package/assets/images/public/bg-login.png +0 -0
- package/assets/images/public/favicon.ico +0 -0
- package/assets/images/public/logo_orange.png +0 -0
- package/assets/images/public/preloader_2.png +0 -0
- package/assets/images/swich.png +0 -0
- package/assets/images/table_img.jpg +0 -0
- package/assets/images/webiny-logo.svg +20 -0
- package/assets/images/webiny-orange-logo.svg +20 -0
- package/components/AdminLayout.d.ts +7 -0
- package/components/AdminLayout.js +35 -0
- package/components/AppInstaller/Sidebar.d.ts +7 -0
- package/components/AppInstaller/Sidebar.js +158 -0
- package/components/AppInstaller/assets/sign-in-divider.svg +19 -0
- package/components/AppInstaller/index.d.ts +5 -0
- package/components/AppInstaller/index.js +134 -0
- package/components/AppInstaller/styled.d.ts +7 -0
- package/components/AppInstaller/styled.js +73 -0
- package/components/AppInstaller/useInstaller.d.ts +11 -0
- package/components/AppInstaller/useInstaller.js +279 -0
- package/components/EmptyView.d.ts +8 -0
- package/components/EmptyView.js +56 -0
- package/components/FileManager/BottomInfoBar/SupportedFileTypes.d.ts +5 -0
- package/components/FileManager/BottomInfoBar/SupportedFileTypes.js +35 -0
- package/components/FileManager/BottomInfoBar/UploadStatus.d.ts +5 -0
- package/components/FileManager/BottomInfoBar/UploadStatus.js +47 -0
- package/components/FileManager/BottomInfoBar.d.ts +3 -0
- package/components/FileManager/BottomInfoBar.js +42 -0
- package/components/FileManager/DropFilesHere.d.ts +8 -0
- package/components/FileManager/DropFilesHere.js +58 -0
- package/components/FileManager/File.d.ts +18 -0
- package/components/FileManager/File.js +129 -0
- package/components/FileManager/FileDetails/Name.d.ts +6 -0
- package/components/FileManager/FileDetails/Name.js +113 -0
- package/components/FileManager/FileDetails/Tags.d.ts +6 -0
- package/components/FileManager/FileDetails/Tags.js +241 -0
- package/components/FileManager/FileDetails.d.ts +23 -0
- package/components/FileManager/FileDetails.js +392 -0
- package/components/FileManager/FileManagerContext.d.ts +23 -0
- package/components/FileManager/FileManagerContext.js +174 -0
- package/components/FileManager/FileManagerView.d.ts +23 -0
- package/components/FileManager/FileManagerView.js +632 -0
- package/components/FileManager/LeftSidebar.d.ts +8 -0
- package/components/FileManager/LeftSidebar.js +95 -0
- package/components/FileManager/NoPermissionView.d.ts +3 -0
- package/components/FileManager/NoPermissionView.js +70 -0
- package/components/FileManager/NoResults.d.ts +2 -0
- package/components/FileManager/NoResults.js +13 -0
- package/components/FileManager/getFileTypePlugin.d.ts +1 -0
- package/components/FileManager/getFileTypePlugin.js +27 -0
- package/components/FileManager/getFileUploader.d.ts +2 -0
- package/components/FileManager/getFileUploader.js +10 -0
- package/components/FileManager/graphql.d.ts +6 -0
- package/components/FileManager/graphql.js +17 -0
- package/components/FileManager/icons/content_copy-black-24px.svg +1 -0
- package/components/FileManager/icons/delete.svg +12 -0
- package/components/FileManager/icons/privacy_tip-24px.svg +10 -0
- package/components/FileManager/icons/round-check_box-24px.svg +4 -0
- package/components/FileManager/icons/round-check_box_outline_blank-24px.svg +4 -0
- package/components/FileManager/icons/round-cloud_download-24px.svg +4 -0
- package/components/FileManager/icons/round-cloud_upload-24px.svg +4 -0
- package/components/FileManager/icons/round-description-24px.svg +4 -0
- package/components/FileManager/icons/round-edit-24px.svg +4 -0
- package/components/FileManager/icons/round-info-24px.svg +4 -0
- package/components/FileManager/icons/round-label-24px.svg +4 -0
- package/components/FileManager/icons/round-more_vert-24px.svg +4 -0
- package/components/FileManager/icons/round-search-24px.svg +20 -0
- package/components/FileManager/outputFileSelectionError.d.ts +2 -0
- package/components/FileManager/outputFileSelectionError.js +39 -0
- package/components/FileManager.d.ts +18 -0
- package/components/FileManager.js +133 -0
- package/components/FloatingActionButton.d.ts +3 -0
- package/components/FloatingActionButton.js +17 -0
- package/components/MultiImageUpload.d.ts +4 -0
- package/components/MultiImageUpload.js +20 -0
- package/components/OverlayLayout/OverlayLayout.d.ts +25 -0
- package/components/OverlayLayout/OverlayLayout.js +159 -0
- package/components/OverlayLayout/icons/close.svg +13 -0
- package/components/OverlayLayout/icons/navigate_before.svg +16 -0
- package/components/OverlayLayout/index.d.ts +1 -0
- package/components/OverlayLayout/index.js +1 -0
- package/components/Permissions/Permissions.d.ts +7 -0
- package/components/Permissions/Permissions.js +37 -0
- package/components/Permissions/StyledComponents.d.ts +6 -0
- package/components/Permissions/StyledComponents.js +19 -0
- package/components/Permissions/index.d.ts +2 -0
- package/components/Permissions/index.js +2 -0
- package/components/RichTextEditor/RichTextEditor.d.ts +3 -0
- package/components/RichTextEditor/RichTextEditor.js +15 -0
- package/components/RichTextEditor/index.d.ts +2 -0
- package/components/RichTextEditor/index.js +2 -0
- package/components/RichTextEditor/styles.scss +64 -0
- package/components/RichTextEditor/tools/header/index.d.ts +228 -0
- package/components/RichTextEditor/tools/header/index.js +731 -0
- package/components/RichTextEditor/tools/header/styles.scss +48 -0
- package/components/RichTextEditor/tools/image/index.d.ts +97 -0
- package/components/RichTextEditor/tools/image/index.js +257 -0
- package/components/RichTextEditor/tools/image/styles.scss +90 -0
- package/components/RichTextEditor/tools/image/svgs.d.ts +6 -0
- package/components/RichTextEditor/tools/image/svgs.js +5 -0
- package/components/RichTextEditor/tools/image/tunes.d.ts +58 -0
- package/components/RichTextEditor/tools/image/tunes.js +134 -0
- package/components/RichTextEditor/tools/image/ui.d.ts +111 -0
- package/components/RichTextEditor/tools/image/ui.js +281 -0
- package/components/RichTextEditor/tools/paragraph/index.d.ts +211 -0
- package/components/RichTextEditor/tools/paragraph/index.js +520 -0
- package/components/RichTextEditor/tools/paragraph/styles.scss +29 -0
- package/components/RichTextEditor/tools/textColor/index.d.ts +58 -0
- package/components/RichTextEditor/tools/textColor/index.js +232 -0
- package/components/RichTextEditor/tools/textColor/styles.scss +21 -0
- package/components/RichTextEditor/tools/utils.d.ts +19 -0
- package/components/RichTextEditor/tools/utils.js +24 -0
- package/components/SearchUI.d.ts +8 -0
- package/components/SearchUI.js +59 -0
- package/components/SimpleForm/SimpleForm.d.ts +21 -0
- package/components/SimpleForm/SimpleForm.js +75 -0
- package/components/SimpleForm/index.d.ts +1 -0
- package/components/SimpleForm/index.js +1 -0
- package/components/SimpleUI/InputField.d.ts +9 -0
- package/components/SimpleUI/InputField.js +97 -0
- package/components/SingleImageUpload.d.ts +25 -0
- package/components/SingleImageUpload.js +102 -0
- package/components/SplitView/SplitView.d.ts +10 -0
- package/components/SplitView/SplitView.js +76 -0
- package/components/SplitView/index.d.ts +1 -0
- package/components/SplitView/index.js +1 -0
- package/components/index.d.ts +1 -0
- package/components/index.js +1 -0
- package/hooks/useConfirmationDialog.d.ts +10 -0
- package/hooks/useConfirmationDialog.js +47 -0
- package/hooks/useDialog.d.ts +5 -0
- package/hooks/useDialog.js +27 -0
- package/hooks/useSnackbar.d.ts +4 -0
- package/hooks/useSnackbar.js +25 -0
- package/package.json +101 -0
- package/plugins/FileManagerFileTypePlugin.d.ts +33 -0
- package/plugins/FileManagerFileTypePlugin.js +46 -0
- package/plugins/MenuPlugin.d.ts +20 -0
- package/plugins/MenuPlugin.js +41 -0
- package/plugins/PermissionRendererPlugin.d.ts +22 -0
- package/plugins/PermissionRendererPlugin.js +41 -0
- package/plugins/fileManager/fileDefault.d.ts +3 -0
- package/plugins/fileManager/fileDefault.js +20 -0
- package/plugins/fileManager/fileImage/DeleteAction.d.ts +3 -0
- package/plugins/fileManager/fileImage/DeleteAction.js +62 -0
- package/plugins/fileManager/fileImage/EditAction.d.ts +9 -0
- package/plugins/fileManager/fileImage/EditAction.js +143 -0
- package/plugins/fileManager/fileImage/index.d.ts +3 -0
- package/plugins/fileManager/fileImage/index.js +29 -0
- package/plugins/fileManager/icons/edit.svg +17 -0
- package/plugins/fileManager/icons/round-description-24px.svg +1 -0
- package/plugins/fileManager/index.d.ts +2 -0
- package/plugins/fileManager/index.js +3 -0
- package/plugins/globalSearch/SearchBar.d.ts +3 -0
- package/plugins/globalSearch/SearchBar.js +241 -0
- package/plugins/globalSearch/SearchBarDropdown.d.ts +5 -0
- package/plugins/globalSearch/SearchBarDropdown.js +82 -0
- package/plugins/globalSearch/icons/round-search-24px.svg +20 -0
- package/plugins/globalSearch/index.d.ts +8 -0
- package/plugins/globalSearch/index.js +30 -0
- package/plugins/globalSearch/styled.d.ts +9 -0
- package/plugins/globalSearch/styled.js +115 -0
- package/plugins/index.d.ts +6 -0
- package/plugins/index.js +8 -0
- package/plugins/logo/Logo.d.ts +22 -0
- package/plugins/logo/Logo.js +108 -0
- package/plugins/logo/index.d.ts +5 -0
- package/plugins/logo/index.js +32 -0
- package/plugins/menu/documentation.d.ts +4 -0
- package/plugins/menu/documentation.js +16 -0
- package/plugins/menu/fileManager.d.ts +4 -0
- package/plugins/menu/fileManager.js +64 -0
- package/plugins/menu/index.d.ts +6 -0
- package/plugins/menu/index.js +24 -0
- package/plugins/menu/renderers/MenuGroupRenderer.d.ts +7 -0
- package/plugins/menu/renderers/MenuGroupRenderer.js +126 -0
- package/plugins/menu/renderers/MenuLinkRenderer.d.ts +7 -0
- package/plugins/menu/renderers/MenuLinkRenderer.js +52 -0
- package/plugins/menu/renderers/MenuSectionItemRenderer.d.ts +7 -0
- package/plugins/menu/renderers/MenuSectionItemRenderer.js +77 -0
- package/plugins/menu/renderers/MenuSectionRenderer.d.ts +7 -0
- package/plugins/menu/renderers/MenuSectionRenderer.js +51 -0
- package/plugins/menu/slack.d.ts +4 -0
- package/plugins/menu/slack.js +16 -0
- package/plugins/menu/source.d.ts +4 -0
- package/plugins/menu/source.js +16 -0
- package/plugins/uiLayoutRenderer/index.d.ts +3 -0
- package/plugins/uiLayoutRenderer/index.js +63 -0
- package/plugins/userMenu/UserMenuElement.d.ts +7 -0
- package/plugins/userMenu/UserMenuElement.js +43 -0
- package/plugins/userMenu/UserMenuRenderer.d.ts +6 -0
- package/plugins/userMenu/UserMenuRenderer.js +47 -0
- package/plugins/userMenu/index.d.ts +4 -0
- package/plugins/userMenu/index.js +16 -0
- package/styles/material-theme-assignments.scss +333 -0
- package/styles/material.scss +74 -0
- package/styles/theme.scss +43 -0
- package/styles.scss +2 -0
- package/types.d.ts +100 -0
- package/types.js +1 -0
- package/ui/UIElement.d.ts +2 -0
- package/ui/UIElement.js +1 -0
- package/ui/UILayout.d.ts +1 -0
- package/ui/UILayout.js +1 -0
- package/ui/UIRenderer.d.ts +2 -0
- package/ui/UIRenderer.js +1 -0
- package/ui/UIView.d.ts +2 -0
- package/ui/UIView.js +1 -0
- package/ui/elements/AccordionElement.d.ts +27 -0
- package/ui/elements/AccordionElement.js +86 -0
- package/ui/elements/ButtonElement.d.ts +24 -0
- package/ui/elements/ButtonElement.js +78 -0
- package/ui/elements/ButtonGroupElement.d.ts +6 -0
- package/ui/elements/ButtonGroupElement.js +48 -0
- package/ui/elements/GenericElement.d.ts +1 -0
- package/ui/elements/GenericElement.js +1 -0
- package/ui/elements/LabelElement.d.ts +16 -0
- package/ui/elements/LabelElement.js +47 -0
- package/ui/elements/NavigationMenuElement.d.ts +32 -0
- package/ui/elements/NavigationMenuElement.js +158 -0
- package/ui/elements/PanelElement.d.ts +3 -0
- package/ui/elements/PanelElement.js +17 -0
- package/ui/elements/PlaceholderElement.d.ts +5 -0
- package/ui/elements/PlaceholderElement.js +30 -0
- package/ui/elements/SmallButtonElement.d.ts +6 -0
- package/ui/elements/SmallButtonElement.js +47 -0
- package/ui/elements/TypographyElement.d.ts +13 -0
- package/ui/elements/TypographyElement.js +49 -0
- package/ui/elements/ViewElement.d.ts +1 -0
- package/ui/elements/ViewElement.js +1 -0
- package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.d.ts +6 -0
- package/ui/elements/form/DynamicFieldsetElement/DynamicFieldsetRowElement.js +44 -0
- package/ui/elements/form/DynamicFieldsetElement.d.ts +42 -0
- package/ui/elements/form/DynamicFieldsetElement.js +127 -0
- package/ui/elements/form/FileManagerElement/EmptyStateElement.d.ts +4 -0
- package/ui/elements/form/FileManagerElement/EmptyStateElement.js +24 -0
- package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.d.ts +7 -0
- package/ui/elements/form/FileManagerElement/EmptyStateElementRenderer.js +72 -0
- package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.d.ts +13 -0
- package/ui/elements/form/FileManagerElement/FileManagerElementRenderer.js +95 -0
- package/ui/elements/form/FileManagerElement/styled.d.ts +14 -0
- package/ui/elements/form/FileManagerElement/styled.js +106 -0
- package/ui/elements/form/FileManagerElement.d.ts +24 -0
- package/ui/elements/form/FileManagerElement.js +91 -0
- package/ui/elements/form/FormElement.d.ts +21 -0
- package/ui/elements/form/FormElement.js +45 -0
- package/ui/elements/form/FormFieldElement.d.ts +55 -0
- package/ui/elements/form/FormFieldElement.js +183 -0
- package/ui/elements/form/HiddenElement.d.ts +6 -0
- package/ui/elements/form/HiddenElement.js +49 -0
- package/ui/elements/form/InputElement.d.ts +6 -0
- package/ui/elements/form/InputElement.js +55 -0
- package/ui/elements/form/PasswordElement.d.ts +6 -0
- package/ui/elements/form/PasswordElement.js +50 -0
- package/ui/elements/form/README.md +2 -0
- package/ui/elements/form/SelectElement.d.ts +15 -0
- package/ui/elements/form/SelectElement.js +71 -0
- package/ui/elements/form/TextareaElement.d.ts +15 -0
- package/ui/elements/form/TextareaElement.js +56 -0
- package/ui/views/AdminView/ContentElement.d.ts +4 -0
- package/ui/views/AdminView/ContentElement.js +62 -0
- package/ui/views/AdminView/HeaderElement.d.ts +13 -0
- package/ui/views/AdminView/HeaderElement.js +111 -0
- package/ui/views/AdminView/HeaderSectionCenterElement.d.ts +6 -0
- package/ui/views/AdminView/HeaderSectionCenterElement.js +42 -0
- package/ui/views/AdminView/HeaderSectionLeftElement.d.ts +6 -0
- package/ui/views/AdminView/HeaderSectionLeftElement.js +42 -0
- package/ui/views/AdminView/HeaderSectionRightElement.d.ts +6 -0
- package/ui/views/AdminView/HeaderSectionRightElement.js +42 -0
- package/ui/views/AdminView/components/Dialog.d.ts +2 -0
- package/ui/views/AdminView/components/Dialog.js +40 -0
- package/ui/views/AdminView/components/Hamburger.d.ts +3 -0
- package/ui/views/AdminView/components/Hamburger.js +25 -0
- package/ui/views/AdminView/components/Snackbar.d.ts +3 -0
- package/ui/views/AdminView/components/Snackbar.js +28 -0
- package/ui/views/AdminView.d.ts +12 -0
- package/ui/views/AdminView.js +90 -0
- package/ui/views/FormView/FormContainerElement.d.ts +12 -0
- package/ui/views/FormView/FormContainerElement.js +51 -0
- package/ui/views/FormView/FormContentElement.d.ts +3 -0
- package/ui/views/FormView/FormContentElement.js +17 -0
- package/ui/views/FormView/FormFooterElement.d.ts +6 -0
- package/ui/views/FormView/FormFooterElement.js +49 -0
- package/ui/views/FormView/FormHeaderElement.d.ts +14 -0
- package/ui/views/FormView/FormHeaderElement.js +81 -0
- package/ui/views/FormView.d.ts +40 -0
- package/ui/views/FormView.js +160 -0
- package/ui/views/NavigationView/ContentElement.d.ts +10 -0
- package/ui/views/NavigationView/ContentElement.js +86 -0
- package/ui/views/NavigationView/FooterElement.d.ts +13 -0
- package/ui/views/NavigationView/FooterElement.js +57 -0
- package/ui/views/NavigationView/HeaderElement.d.ts +16 -0
- package/ui/views/NavigationView/HeaderElement.js +66 -0
- package/ui/views/NavigationView/NavigationViewRenderer.d.ts +6 -0
- package/ui/views/NavigationView/NavigationViewRenderer.js +38 -0
- package/ui/views/NavigationView/Styled.d.ts +7 -0
- package/ui/views/NavigationView/Styled.js +47 -0
- package/ui/views/NavigationView/legacyMenu.d.ts +22 -0
- package/ui/views/NavigationView/legacyMenu.js +1 -0
- package/ui/views/NavigationView/useNavigation.d.ts +6 -0
- package/ui/views/NavigationView/useNavigation.js +22 -0
- package/ui/views/NavigationView.d.ts +26 -0
- package/ui/views/NavigationView.js +204 -0
- package/ui/views/OverlayView/ContentElement.d.ts +6 -0
- package/ui/views/OverlayView/ContentElement.js +42 -0
- package/ui/views/OverlayView/HeaderElement.d.ts +24 -0
- package/ui/views/OverlayView/HeaderElement.js +115 -0
- package/ui/views/OverlayView/HeaderTitleElement.d.ts +13 -0
- package/ui/views/OverlayView/HeaderTitleElement.js +54 -0
- package/ui/views/OverlayView/useOverlayView.d.ts +6 -0
- package/ui/views/OverlayView/useOverlayView.js +38 -0
- package/ui/views/OverlayView.d.ts +31 -0
- package/ui/views/OverlayView.js +176 -0
- package/ui/views/SplitView/SplitViewPanelElement.d.ts +11 -0
- package/ui/views/SplitView/SplitViewPanelElement.js +72 -0
- package/ui/views/SplitView.d.ts +21 -0
- 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,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,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 {};
|