box-ui-elements 16.0.0-beta.8 → 16.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/explorer.css +1 -1
- package/dist/explorer.js +19 -58
- package/dist/openwith.css +1 -1
- package/dist/openwith.js +10 -10
- package/dist/picker.css +1 -1
- package/dist/picker.js +12 -12
- package/dist/preview.css +1 -1
- package/dist/preview.js +17 -56
- package/dist/sharing.css +1 -1
- package/dist/sharing.js +34 -34
- package/dist/sidebar.css +1 -1
- package/dist/sidebar.js +17 -56
- package/dist/uploader.css +1 -1
- package/dist/uploader.js +12 -12
- package/es/api/APIFactory.js +27 -0
- package/es/api/APIFactory.js.flow +26 -0
- package/es/api/APIFactory.js.map +1 -1
- package/es/api/Annotations.js +180 -27
- package/es/api/Annotations.js.flow +150 -14
- package/es/api/Annotations.js.map +1 -1
- package/es/api/Comments.js +2 -2
- package/es/api/Comments.js.flow +5 -4
- package/es/api/Comments.js.map +1 -1
- package/es/api/Feed.js +578 -69
- package/es/api/Feed.js.flow +677 -17
- package/es/api/Feed.js.map +1 -1
- package/es/api/FileCollaborators.js +29 -0
- package/es/api/FileCollaborators.js.flow +30 -0
- package/es/api/FileCollaborators.js.map +1 -1
- package/es/api/ThreadedComments.js +64 -27
- package/es/api/ThreadedComments.js.flow +54 -29
- package/es/api/ThreadedComments.js.map +1 -1
- package/es/api/fixtures.js +381 -0
- package/es/api/fixtures.js.flow +401 -0
- package/es/api/fixtures.js.map +1 -0
- package/es/api/messages.js +4 -0
- package/es/api/messages.js.flow +5 -0
- package/es/api/messages.js.map +1 -1
- package/es/api/utils.js +33 -0
- package/es/api/utils.js.flow +30 -0
- package/es/api/utils.js.map +1 -0
- package/es/common/types/annotations.js.flow +18 -10
- package/es/common/types/feed.js +1 -1
- package/es/common/types/feed.js.flow +40 -4
- package/es/common/types/feed.js.map +1 -1
- package/es/components/accessible-svg/AccessibleSVG.stories.js +20 -0
- package/es/components/accessible-svg/AccessibleSVG.stories.js.map +1 -0
- package/es/components/badge/Badge.stories.js +1 -13
- package/es/components/badge/Badge.stories.js.map +1 -1
- package/es/components/badge/BetaBadge.stories.js +10 -0
- package/es/components/badge/BetaBadge.stories.js.map +1 -0
- package/es/components/badge/TrialBadge.stories.js +10 -0
- package/es/components/badge/TrialBadge.stories.js.map +1 -0
- package/es/components/badge/UpgradeBadge.stories.js +10 -0
- package/es/components/badge/UpgradeBadge.stories.js.map +1 -0
- package/es/components/breadcrumb/Breadcrumb.js +48 -35
- package/es/components/breadcrumb/Breadcrumb.js.flow +68 -42
- package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
- package/es/components/breadcrumb/EllipsisCrumb.js +5 -3
- package/es/components/breadcrumb/EllipsisCrumb.js.flow +10 -6
- package/es/components/breadcrumb/EllipsisCrumb.js.map +1 -1
- package/es/components/count-badge/CountBadge.stories.js +1 -1
- package/es/components/count-badge/CountBadge.stories.js.map +1 -1
- package/es/components/draggable-list/DraggableList.stories.js +119 -5
- package/es/components/draggable-list/DraggableList.stories.js.map +1 -1
- package/es/components/dropdown-menu/DropdownMenu.js +9 -0
- package/es/components/dropdown-menu/DropdownMenu.js.flow +11 -0
- package/es/components/dropdown-menu/DropdownMenu.js.map +1 -1
- package/es/components/dropdown-menu/DropdownMenu.scss +3 -3
- package/es/components/infinite-scroll/InfiniteScroll.js +4 -2
- package/es/components/infinite-scroll/InfiniteScroll.js.map +1 -1
- package/es/components/modal/Modal.scss +5 -1
- package/es/components/search-form/SearchForm.js +1 -1
- package/es/components/search-form/SearchForm.js.flow +1 -1
- package/es/components/search-form/SearchForm.js.map +1 -1
- package/es/components/table/makeSelectable.js +304 -97
- package/es/components/table/makeSelectable.js.flow +299 -98
- package/es/components/table/makeSelectable.js.map +1 -1
- package/es/components/tooltip/Tooltip.js +3 -2
- package/es/components/tooltip/Tooltip.js.map +1 -1
- package/es/constants.js +11 -0
- package/es/constants.js.flow +11 -0
- package/es/constants.js.map +1 -1
- package/es/elements/common/annotator-context/index.js +1 -0
- package/es/elements/common/annotator-context/index.js.flow +4 -0
- package/es/elements/common/annotator-context/index.js.map +1 -1
- package/es/elements/common/annotator-context/types.js +12 -0
- package/es/elements/common/annotator-context/types.js.flow +77 -35
- package/es/elements/common/annotator-context/types.js.map +1 -1
- package/es/elements/common/annotator-context/useAnnotatorEvents.js +205 -0
- package/es/elements/common/annotator-context/useAnnotatorEvents.js.flow +52 -0
- package/es/elements/common/annotator-context/useAnnotatorEvents.js.map +1 -0
- package/es/elements/common/annotator-context/withAnnotations.js +224 -5
- package/es/elements/common/annotator-context/withAnnotations.js.flow +73 -36
- package/es/elements/common/annotator-context/withAnnotations.js.map +1 -1
- package/es/elements/common/annotator-context/withAnnotatorContext.js +12 -4
- package/es/elements/common/annotator-context/withAnnotatorContext.js.flow +29 -9
- package/es/elements/common/annotator-context/withAnnotatorContext.js.map +1 -1
- package/es/elements/common/current-user/index.js +3 -0
- package/es/elements/common/current-user/index.js.flow +8 -0
- package/es/elements/common/current-user/index.js.map +1 -0
- package/es/elements/common/current-user/withCurrentUser.js +139 -0
- package/es/elements/common/current-user/withCurrentUser.js.flow +40 -0
- package/es/elements/common/current-user/withCurrentUser.js.map +1 -0
- package/es/elements/common/flowTypes.js.flow +22 -4
- package/es/elements/common/flowTypes.js.map +1 -1
- package/es/elements/common/interactionTargets.js +2 -0
- package/es/elements/common/interactionTargets.js.flow +2 -0
- package/es/elements/common/interactionTargets.js.map +1 -1
- package/es/elements/common/logger/Logger.js +1 -1
- package/es/elements/common/logger/Logger.js.flow +1 -1
- package/es/elements/common/logger/Logger.js.map +1 -1
- package/es/elements/common/messages.js +4 -0
- package/es/elements/common/messages.js.flow +5 -0
- package/es/elements/common/messages.js.map +1 -1
- package/es/elements/content-explorer/DeleteConfirmationDialog.js +2 -1
- package/es/elements/content-explorer/DeleteConfirmationDialog.js.flow +3 -1
- package/es/elements/content-explorer/DeleteConfirmationDialog.js.map +1 -1
- package/es/elements/content-explorer/DeleteConfirmationDialog.scss +5 -0
- package/es/elements/content-explorer/stories/DeleteConfirmationDialog.stories.js +58 -0
- package/es/elements/content-explorer/stories/DeleteConfirmationDialog.stories.js.flow +60 -0
- package/es/elements/content-explorer/stories/DeleteConfirmationDialog.stories.js.map +1 -0
- package/es/elements/content-sidebar/ActivitySidebar.js +323 -197
- package/es/elements/content-sidebar/ActivitySidebar.js.flow +381 -154
- package/es/elements/content-sidebar/ActivitySidebar.js.map +1 -1
- package/es/elements/content-sidebar/ActivitySidebarFilter.js +52 -0
- package/es/elements/content-sidebar/ActivitySidebarFilter.js.flow +59 -0
- package/es/elements/content-sidebar/ActivitySidebarFilter.js.map +1 -0
- package/es/elements/content-sidebar/ActivitySidebarFilter.scss +4 -0
- package/es/elements/content-sidebar/DetailsSidebar.js +50 -25
- package/es/elements/content-sidebar/DetailsSidebar.js.flow +32 -4
- package/es/elements/content-sidebar/DetailsSidebar.js.map +1 -1
- package/es/elements/content-sidebar/Sidebar.js +4 -1
- package/es/elements/content-sidebar/Sidebar.js.flow +6 -1
- package/es/elements/content-sidebar/Sidebar.js.map +1 -1
- package/es/elements/content-sidebar/SidebarContentInsights.js +45 -0
- package/es/elements/content-sidebar/SidebarContentInsights.js.map +1 -0
- package/es/elements/content-sidebar/SidebarContentInsights.scss +6 -0
- package/es/elements/content-sidebar/SidebarPanels.js +2 -0
- package/es/elements/content-sidebar/SidebarPanels.js.flow +4 -0
- package/es/elements/content-sidebar/SidebarPanels.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActiveState.js +91 -10
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActiveState.js.flow +122 -24
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActiveState.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityFeed.js +27 -15
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityFeed.js.flow +59 -18
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityFeed.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.js +101 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.js.flow +126 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.scss +17 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.js +69 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.js.flow +85 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.scss +16 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.js +62 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.js.flow +59 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.scss +22 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/activityFeedUtils.js +2 -2
- package/es/elements/content-sidebar/activity-feed/activity-feed/activityFeedUtils.js.flow +2 -2
- package/es/elements/content-sidebar/activity-feed/activity-feed/activityFeedUtils.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/activity-feed/fixtures.js +55 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/fixtures.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/messages.js +16 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/messages.js.flow +20 -0
- package/es/elements/content-sidebar/activity-feed/activity-feed/messages.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.js +121 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.js.flow +117 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.scss +7 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.js +75 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.js.flow +105 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.scss +5 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.js +77 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.js.flow +86 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.scss +3 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/errors.js +11 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/errors.js.flow +26 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/errors.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/index.js +2 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/index.js.flow +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/index.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/messages.js +17 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/messages.js.flow +21 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/messages.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useAnnotationAPI.js +180 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useAnnotationAPI.js.flow +203 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useAnnotationAPI.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useRepliesAPI.js +124 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useRepliesAPI.js.flow +121 -0
- package/es/elements/content-sidebar/activity-feed/annotation-thread/useRepliesAPI.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivity.js +19 -5
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivity.js.flow +24 -4
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivity.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivityMenu.js +25 -4
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivityMenu.js.flow +36 -2
- package/es/elements/content-sidebar/activity-feed/annotations/AnnotationActivityMenu.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/annotations/messages.js +8 -0
- package/es/elements/content-sidebar/activity-feed/annotations/messages.js.flow +10 -0
- package/es/elements/content-sidebar/activity-feed/annotations/messages.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/comment/Comment.js +61 -28
- package/es/elements/content-sidebar/activity-feed/comment/Comment.js.flow +54 -10
- package/es/elements/content-sidebar/activity-feed/comment/Comment.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/comment/messages.js +8 -0
- package/es/elements/content-sidebar/activity-feed/comment/messages.js.flow +10 -0
- package/es/elements/content-sidebar/activity-feed/comment/messages.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/comment-form/CommentForm.js +4 -2
- package/es/elements/content-sidebar/activity-feed/comment-form/CommentForm.js.flow +3 -1
- package/es/elements/content-sidebar/activity-feed/comment-form/CommentForm.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.js +16 -5
- package/es/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.js.flow +34 -4
- package/es/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.scss +40 -3
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessage.js +49 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessage.js.flow +42 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessage.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessageToggle.js +21 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessageToggle.js.flow +24 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessageToggle.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/messages.js +12 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/messages.js.flow +15 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-message/messages.js.map +1 -1
- package/es/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.js +24 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.js.flow +30 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.scss +6 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/index.js +2 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/index.js.flow +2 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/index.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/messages.js +9 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/messages.js.flow +13 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-status/messages.js.map +1 -0
- package/es/elements/content-sidebar/activity-feed/common/activity-timestamp/ActivityTimestamp.scss +1 -1
- package/es/elements/content-sidebar/fixtures.js +181 -0
- package/es/elements/content-sidebar/fixtures.js.flow +185 -0
- package/es/elements/content-sidebar/fixtures.js.map +1 -0
- package/es/elements/content-sidebar/flowTypes.js.flow +9 -25
- package/es/elements/content-sidebar/messages.js +8 -0
- package/es/elements/content-sidebar/messages.js.flow +10 -0
- package/es/elements/content-sidebar/messages.js.map +1 -1
- package/es/elements/content-sidebar/withErrorHandling.js.flow +1 -1
- package/es/elements/content-sidebar/withErrorHandling.js.map +1 -1
- package/es/elements/content-sidebar/withSidebarAnnotations.js +215 -30
- package/es/elements/content-sidebar/withSidebarAnnotations.js.flow +162 -11
- package/es/elements/content-sidebar/withSidebarAnnotations.js.map +1 -1
- package/es/elements/content-uploader/OverallUploadsProgressBar.js +10 -8
- package/es/elements/content-uploader/OverallUploadsProgressBar.js.flow +11 -12
- package/es/elements/content-uploader/OverallUploadsProgressBar.js.map +1 -1
- package/es/features/classification/Classification.scss +1 -1
- package/es/features/classification/security-controls/SecurityControlsItem.scss +1 -0
- package/es/features/classification/security-controls/messages.js +8 -0
- package/es/features/classification/security-controls/messages.js.flow +10 -0
- package/es/features/classification/security-controls/messages.js.map +1 -1
- package/es/features/classification/security-controls/utils.js +4 -7
- package/es/features/classification/security-controls/utils.js.flow +8 -12
- package/es/features/classification/security-controls/utils.js.map +1 -1
- package/es/features/content-explorer/content-explorer/ContentExplorer.js +6 -1
- package/es/features/content-explorer/content-explorer/ContentExplorer.js.flow +4 -0
- package/es/features/content-explorer/content-explorer/ContentExplorer.js.map +1 -1
- package/es/features/content-explorer/content-explorer/ContentExplorer.scss +4 -0
- package/es/features/content-explorer/content-explorer/ContentExplorerBreadcrumbs.js +15 -9
- package/es/features/content-explorer/content-explorer/ContentExplorerBreadcrumbs.js.flow +14 -11
- package/es/features/content-explorer/content-explorer/ContentExplorerBreadcrumbs.js.map +1 -1
- package/es/features/content-explorer/content-explorer/ContentExplorerHeaderActions.js +4 -1
- package/es/features/content-explorer/content-explorer/ContentExplorerHeaderActions.js.flow +4 -1
- package/es/features/content-explorer/content-explorer/ContentExplorerHeaderActions.js.map +1 -1
- package/es/features/content-explorer/content-explorer-modal/ContentExplorerModal.js +6 -3
- package/es/features/content-explorer/content-explorer-modal/ContentExplorerModal.js.flow +5 -1
- package/es/features/content-explorer/content-explorer-modal/ContentExplorerModal.js.map +1 -1
- package/es/features/content-explorer/content-explorer-modal-container/ContentExplorerModalContainer.js +6 -1
- package/es/features/content-explorer/content-explorer-modal-container/ContentExplorerModalContainer.js.flow +5 -1
- package/es/features/content-explorer/content-explorer-modal-container/ContentExplorerModalContainer.js.map +1 -1
- package/es/features/content-explorer/prop-types.js +7 -1
- package/es/features/content-explorer/prop-types.js.flow +8 -0
- package/es/features/content-explorer/prop-types.js.map +1 -1
- package/es/features/content-insights/CompactCount.js +24 -0
- package/es/features/content-insights/CompactCount.js.map +1 -0
- package/es/features/content-insights/ContentAnalyticsErrorState.js +35 -0
- package/es/features/content-insights/ContentAnalyticsErrorState.js.map +1 -0
- package/es/features/content-insights/ContentAnalyticsErrorState.scss +17 -0
- package/es/features/content-insights/ContentInsightsSummary.js +42 -0
- package/es/features/content-insights/ContentInsightsSummary.js.map +1 -0
- package/es/features/content-insights/ContentInsightsSummary.scss +12 -0
- package/es/features/content-insights/ContentInsightsSummaryGhostState.js +19 -0
- package/es/features/content-insights/ContentInsightsSummaryGhostState.js.map +1 -0
- package/es/features/content-insights/ContentInsightsSummaryGhostState.scss +9 -0
- package/es/features/content-insights/GraphCardGhostState.js +25 -0
- package/es/features/content-insights/GraphCardGhostState.js.map +1 -0
- package/es/features/content-insights/GraphCardGhostState.scss +18 -0
- package/es/features/content-insights/GraphCardPreviewsSummary.js +30 -0
- package/es/features/content-insights/GraphCardPreviewsSummary.js.map +1 -0
- package/es/features/content-insights/GraphCardPreviewsSummary.scss +10 -0
- package/es/features/content-insights/GraphGhostState.js +21 -0
- package/es/features/content-insights/GraphGhostState.js.map +1 -0
- package/es/features/content-insights/GraphGhostState.scss +11 -0
- package/es/features/content-insights/HeaderWithCount.js +23 -0
- package/es/features/content-insights/HeaderWithCount.js.map +1 -0
- package/es/features/content-insights/HeaderWithCount.scss +10 -0
- package/es/features/content-insights/MetricSummary.js +85 -0
- package/es/features/content-insights/MetricSummary.js.map +1 -0
- package/es/features/content-insights/MetricSummary.scss +14 -0
- package/es/features/content-insights/OpenContentInsightsButton.js +16 -0
- package/es/features/content-insights/OpenContentInsightsButton.js.map +1 -0
- package/es/features/content-insights/TrendPill.js +61 -0
- package/es/features/content-insights/TrendPill.js.map +1 -0
- package/es/features/content-insights/TrendPill.scss +33 -0
- package/es/features/content-insights/_mixins.scss +7 -0
- package/es/features/content-insights/_variables.scss +4 -0
- package/es/features/content-insights/charts/bar/Bar.js +57 -0
- package/es/features/content-insights/charts/bar/Bar.js.map +1 -0
- package/es/features/content-insights/charts/bar/Bar.scss +27 -0
- package/es/features/content-insights/charts/bar/BarChart.js +70 -0
- package/es/features/content-insights/charts/bar/BarChart.js.map +1 -0
- package/es/features/content-insights/charts/bar/BarChart.scss +56 -0
- package/es/features/content-insights/charts/types.js +2 -0
- package/es/{common/types/threadedComments.js.map → features/content-insights/charts/types.js.map} +1 -1
- package/es/features/content-insights/constants.js +54 -0
- package/es/features/content-insights/constants.js.map +1 -0
- package/es/features/content-insights/messages.js +69 -0
- package/es/features/content-insights/messages.js.map +1 -0
- package/es/features/content-insights/numberUtils.js +10 -0
- package/es/features/content-insights/numberUtils.js.map +1 -0
- package/es/features/content-insights/types.js +2 -0
- package/es/features/content-insights/types.js.map +1 -0
- package/es/features/item-details/ItemProperties.scss +1 -1
- package/es/features/shared-link-settings-modal/SharedLinkSettingsModal.js +5 -3
- package/es/features/shared-link-settings-modal/SharedLinkSettingsModal.js.flow +4 -2
- package/es/features/shared-link-settings-modal/SharedLinkSettingsModal.js.map +1 -1
- package/es/features/unified-share-modal/ContactRestrictionNotice.js +34 -8
- package/es/features/unified-share-modal/ContactRestrictionNotice.js.flow +36 -6
- package/es/features/unified-share-modal/ContactRestrictionNotice.js.map +1 -1
- package/es/features/unified-share-modal/EmailForm.js +59 -47
- package/es/features/unified-share-modal/EmailForm.js.flow +31 -13
- package/es/features/unified-share-modal/EmailForm.js.map +1 -1
- package/es/features/unified-share-modal/UnifiedShareForm.js +112 -103
- package/es/features/unified-share-modal/UnifiedShareForm.js.flow +25 -8
- package/es/features/unified-share-modal/UnifiedShareForm.js.map +1 -1
- package/es/features/unified-share-modal/UnifiedShareModal.js +1 -0
- package/es/features/unified-share-modal/UnifiedShareModal.js.flow +1 -0
- package/es/features/unified-share-modal/UnifiedShareModal.js.map +1 -1
- package/es/features/unified-share-modal/flowTypes.js.flow +4 -2
- package/es/features/unified-share-modal/flowTypes.js.map +1 -1
- package/es/features/unified-share-modal/messages.js +12 -8
- package/es/features/unified-share-modal/messages.js.flow +14 -8
- package/es/features/unified-share-modal/messages.js.map +1 -1
- package/es/features/unified-share-modal/utils/hasRestrictedContacts.js +9 -4
- package/es/features/unified-share-modal/utils/hasRestrictedContacts.js.flow +10 -3
- package/es/features/unified-share-modal/utils/hasRestrictedContacts.js.map +1 -1
- package/es/features/unified-share-modal/utils/isRestrictedContact.js +15 -0
- package/es/features/unified-share-modal/utils/isRestrictedContact.js.flow +21 -0
- package/es/features/unified-share-modal/utils/isRestrictedContact.js.map +1 -0
- package/es/icon/fill/Alert16.js +3 -2
- package/es/icon/fill/Alert16.js.flow +3 -2
- package/es/icon/fill/Alert16.js.map +1 -1
- package/es/icon/fill/AlertBadge16.js +31 -0
- package/es/icon/fill/AlertBadge16.js.flow +29 -0
- package/es/icon/fill/AlertBadge16.js.map +1 -0
- package/es/icon/fill/AlertBadge16.stories.js +13 -0
- package/es/icon/fill/AlertBadge16.stories.js.map +1 -0
- package/es/icon/fill/Info16.js +2 -2
- package/es/icon/fill/Info16.js.flow +1 -1
- package/es/icon/fill/Info16.js.map +1 -1
- package/es/icon/fill/InfoBadge16.js +30 -0
- package/es/icon/fill/InfoBadge16.js.flow +28 -0
- package/es/icon/fill/InfoBadge16.js.map +1 -0
- package/es/icon/fill/InfoBadge16.stories.js +13 -0
- package/es/icon/fill/InfoBadge16.stories.js.map +1 -0
- package/es/icon/fill/UserSettings16.js +38 -0
- package/es/icon/fill/UserSettings16.js.flow +38 -0
- package/es/icon/fill/UserSettings16.js.map +1 -0
- package/es/icon/fill/UserSettings16.stories.js +13 -0
- package/es/icon/fill/UserSettings16.stories.js.map +1 -0
- package/es/icon/line/AlertBubble16.js +31 -0
- package/es/icon/line/AlertBubble16.js.flow +29 -0
- package/es/icon/line/AlertBubble16.js.map +1 -0
- package/es/icon/line/AlertBubble16.stories.js +13 -0
- package/es/icon/line/AlertBubble16.stories.js.map +1 -0
- package/es/icon/line/AvatarXBadge16.js +45 -0
- package/es/icon/line/AvatarXBadge16.js.flow +39 -0
- package/es/icon/line/AvatarXBadge16.js.map +1 -0
- package/es/icon/line/AvatarXBadge16.stories.js +13 -0
- package/es/icon/line/AvatarXBadge16.stories.js.map +1 -0
- package/es/icon/line/CoEdit16.js +32 -0
- package/es/icon/line/CoEdit16.js.flow +30 -0
- package/es/icon/line/CoEdit16.js.map +1 -0
- package/es/icon/line/CoEdit16.stories.js +13 -0
- package/es/icon/line/CoEdit16.stories.js.map +1 -0
- package/es/icon/line/Collaborations16.js +32 -0
- package/es/icon/line/Collaborations16.js.flow +30 -0
- package/es/icon/line/Collaborations16.js.map +1 -0
- package/es/icon/line/Collaborations16.stories.js +13 -0
- package/es/icon/line/Collaborations16.stories.js.map +1 -0
- package/es/icon/line/CommentBubble16.js +35 -0
- package/es/icon/line/CommentBubble16.js.flow +34 -0
- package/es/icon/line/CommentBubble16.js.map +1 -0
- package/es/icon/line/CommentBubble16.stories.js +13 -0
- package/es/icon/line/CommentBubble16.stories.js.map +1 -0
- package/es/src/components/accessible-svg/AccessibleSVG.stories.d.ts +7 -0
- package/es/src/components/badge/Badge.stories.d.ts +0 -3
- package/es/src/components/badge/BetaBadge.stories.d.ts +6 -0
- package/es/src/components/badge/TrialBadge.stories.d.ts +6 -0
- package/es/src/components/badge/UpgradeBadge.stories.d.ts +6 -0
- package/es/src/components/draggable-list/DraggableList.stories.d.ts +3 -3
- package/es/src/components/infinite-scroll/InfiniteScroll.d.ts +1 -1
- package/es/src/components/tooltip/Tooltip.d.ts +2 -0
- package/es/src/elements/common/annotator-context/__tests__/useAnnotatorEvents.test.d.ts +1 -0
- package/es/src/elements/common/annotator-context/index.d.ts +1 -0
- package/es/src/elements/common/annotator-context/types.d.ts +28 -6
- package/es/src/elements/common/annotator-context/useAnnotatorEvents.d.ts +52 -0
- package/es/src/elements/common/annotator-context/withAnnotations.d.ts +11 -2
- package/es/src/elements/common/annotator-context/withAnnotatorContext.d.ts +6 -2
- package/es/src/elements/common/current-user/__tests__/withCurrentUser.test.d.ts +1 -0
- package/es/src/elements/common/current-user/index.d.ts +2 -0
- package/es/src/elements/common/current-user/withCurrentUser.d.ts +20 -0
- package/es/src/elements/content-sidebar/SidebarContentInsights.d.ts +15 -0
- package/es/src/elements/content-sidebar/__tests__/SidebarContentInsights.test.d.ts +1 -0
- package/es/src/elements/content-sidebar/activity-feed/activity-feed/fixtures.d.ts +55 -0
- package/es/src/features/content-insights/CompactCount.d.ts +15 -0
- package/es/src/features/content-insights/ContentAnalyticsErrorState.d.ts +7 -0
- package/es/src/features/content-insights/ContentInsightsSummary.d.ts +12 -0
- package/es/src/features/content-insights/ContentInsightsSummaryGhostState.d.ts +3 -0
- package/es/src/features/content-insights/GraphCardGhostState.d.ts +3 -0
- package/es/src/features/content-insights/GraphCardPreviewsSummary.d.ts +16 -0
- package/es/src/features/content-insights/GraphGhostState.d.ts +3 -0
- package/es/src/features/content-insights/HeaderWithCount.d.ts +7 -0
- package/es/src/features/content-insights/MetricSummary.d.ts +18 -0
- package/es/src/features/content-insights/OpenContentInsightsButton.d.ts +5 -0
- package/es/src/features/content-insights/TrendPill.d.ts +15 -0
- package/es/src/features/content-insights/__tests__/CompactCount.test.d.ts +1 -0
- package/es/src/features/content-insights/__tests__/ContentAnalyticsErrorState.test.d.ts +1 -0
- package/es/src/features/content-insights/__tests__/ContentInsightsSummary.test.d.ts +1 -0
- package/es/src/features/content-insights/__tests__/GraphCardPreviewsSummary.test.d.ts +1 -0
- package/es/src/features/content-insights/__tests__/HeaderWithCount.test.d.ts +1 -0
- package/es/src/features/content-insights/__tests__/MetricSummary.test.d.ts +1 -0
- package/es/src/features/content-insights/charts/bar/Bar.d.ts +11 -0
- package/es/src/features/content-insights/charts/bar/BarChart.d.ts +19 -0
- package/es/src/features/content-insights/charts/bar/__tests__/Bar.test.d.ts +1 -0
- package/es/src/features/content-insights/charts/bar/__tests__/BarChart.test.d.ts +1 -0
- package/es/src/features/content-insights/charts/types.d.ts +2 -0
- package/es/src/features/content-insights/constants.d.ts +27 -0
- package/es/src/features/content-insights/messages.d.ts +83 -0
- package/es/src/features/content-insights/numberUtils.d.ts +3 -0
- package/es/src/features/content-insights/types.d.ts +24 -0
- package/es/src/icon/fill/AlertBadge16.d.ts +13 -0
- package/es/src/icon/fill/AlertBadge16.stories.d.ts +9 -0
- package/es/src/icon/fill/InfoBadge16.d.ts +13 -0
- package/es/src/icon/fill/InfoBadge16.stories.d.ts +9 -0
- package/es/src/icon/fill/UserSettings16.d.ts +13 -0
- package/es/src/icon/fill/UserSettings16.stories.d.ts +9 -0
- package/es/src/icon/line/AlertBubble16.d.ts +13 -0
- package/es/src/icon/line/AlertBubble16.stories.d.ts +9 -0
- package/es/src/icon/line/AvatarXBadge16.d.ts +13 -0
- package/es/src/icon/line/AvatarXBadge16.stories.d.ts +9 -0
- package/es/src/icon/line/CoEdit16.d.ts +13 -0
- package/es/src/icon/line/CoEdit16.stories.d.ts +9 -0
- package/es/src/icon/line/Collaborations16.d.ts +13 -0
- package/es/src/icon/line/Collaborations16.stories.d.ts +9 -0
- package/es/src/icon/line/CommentBubble16.d.ts +13 -0
- package/es/src/icon/line/CommentBubble16.stories.d.ts +9 -0
- package/es/src/styles/variables.d.ts +3 -1
- package/es/styles/constants/_layout.scss +1 -1
- package/es/styles/constants/_media-queries.scss +2 -0
- package/es/styles/variables.js +6 -2
- package/es/styles/variables.js.flow +4 -2
- package/es/styles/variables.js.map +1 -1
- package/es/utils/error.js +5 -1
- package/es/utils/error.js.flow +5 -1
- package/es/utils/error.js.map +1 -1
- package/es/utils/fields.js +8 -3
- package/es/utils/fields.js.flow +21 -3
- package/es/utils/fields.js.map +1 -1
- package/es/utils/sorter.js.flow +2 -2
- package/es/utils/sorter.js.map +1 -1
- package/i18n/bn-IN.js +45 -7
- package/i18n/bn-IN.properties +83 -7
- package/i18n/da-DK.js +45 -7
- package/i18n/da-DK.properties +83 -7
- package/i18n/de-DE.js +45 -7
- package/i18n/de-DE.properties +83 -7
- package/i18n/en-AU.js +45 -7
- package/i18n/en-AU.properties +83 -7
- package/i18n/en-CA.js +45 -7
- package/i18n/en-CA.properties +83 -7
- package/i18n/en-GB.js +45 -7
- package/i18n/en-GB.properties +83 -7
- package/i18n/en-US.js +45 -7
- package/i18n/en-US.properties +83 -7
- package/i18n/en-x-pseudo.js +891 -854
- package/i18n/en-x-pseudo.properties +941 -843
- package/i18n/es-419.js +45 -7
- package/i18n/es-419.properties +83 -7
- package/i18n/es-ES.js +45 -7
- package/i18n/es-ES.properties +83 -7
- package/i18n/fi-FI.js +45 -7
- package/i18n/fi-FI.properties +83 -7
- package/i18n/fr-CA.js +45 -7
- package/i18n/fr-CA.properties +83 -7
- package/i18n/fr-FR.js +45 -7
- package/i18n/fr-FR.properties +83 -7
- package/i18n/hi-IN.js +45 -7
- package/i18n/hi-IN.properties +83 -7
- package/i18n/it-IT.js +45 -7
- package/i18n/it-IT.properties +83 -7
- package/i18n/ja-JP.js +47 -9
- package/i18n/ja-JP.properties +85 -9
- package/i18n/ko-KR.js +45 -7
- package/i18n/ko-KR.properties +83 -7
- package/i18n/nb-NO.js +45 -7
- package/i18n/nb-NO.properties +83 -7
- package/i18n/nl-NL.js +45 -7
- package/i18n/nl-NL.properties +83 -7
- package/i18n/pl-PL.js +45 -7
- package/i18n/pl-PL.properties +83 -7
- package/i18n/pt-BR.js +45 -7
- package/i18n/pt-BR.properties +83 -7
- package/i18n/ru-RU.js +45 -7
- package/i18n/ru-RU.properties +83 -7
- package/i18n/sv-SE.js +45 -7
- package/i18n/sv-SE.properties +83 -7
- package/i18n/tr-TR.js +45 -7
- package/i18n/tr-TR.properties +83 -7
- package/i18n/zh-CN.js +45 -7
- package/i18n/zh-CN.properties +83 -7
- package/i18n/zh-TW.js +45 -7
- package/i18n/zh-TW.properties +83 -7
- package/package.json +7 -8
- package/src/__mocks__/react-intl.js +4 -0
- package/src/api/APIFactory.js +26 -0
- package/src/api/Annotations.js +150 -14
- package/src/api/Comments.js +5 -4
- package/src/api/Feed.js +677 -17
- package/src/api/FileCollaborators.js +30 -0
- package/src/api/ThreadedComments.js +54 -29
- package/src/api/__tests__/Annotations.test.js +217 -11
- package/src/api/__tests__/Feed.test.js +699 -86
- package/src/api/__tests__/FileCollaborators.test.js +41 -0
- package/src/api/__tests__/ThreadedComments.test.js +47 -10
- package/src/api/__tests__/utils.test.js +11 -0
- package/src/api/fixtures.js +401 -0
- package/src/api/messages.js +5 -0
- package/src/api/utils.js +30 -0
- package/src/common/types/annotations.js +18 -10
- package/src/common/types/feed.js +40 -4
- package/src/components/accessible-svg/AccessibleSVG.stories.tsx +18 -0
- package/src/components/badge/Badge.stories.md +1 -7
- package/src/components/badge/Badge.stories.tsx +1 -10
- package/src/components/badge/BetaBadge.stories.tsx +9 -0
- package/src/components/badge/TrialBadge.stories.tsx +9 -0
- package/src/components/badge/UpgradeBadge.stories.tsx +9 -0
- package/src/components/breadcrumb/Breadcrumb.js +68 -42
- package/src/components/breadcrumb/EllipsisCrumb.js +10 -6
- package/src/components/count-badge/CountBadge.stories.tsx +1 -1
- package/src/components/draggable-list/DraggableList.stories.tsx +72 -5
- package/src/components/dropdown-menu/DropdownMenu.js +11 -0
- package/src/components/dropdown-menu/DropdownMenu.scss +3 -3
- package/src/components/dropdown-menu/__tests__/DropdownMenu.test.js +38 -0
- package/src/components/grid-view/__tests__/__snapshots__/GridViewSlider.test.js.snap +1 -0
- package/src/components/infinite-scroll/InfiniteScroll.md +1 -1
- package/src/components/infinite-scroll/InfiniteScroll.tsx +5 -2
- package/src/components/infinite-scroll/__tests__/InfiniteScroll.test.tsx +115 -127
- package/src/components/modal/Modal.scss +5 -1
- package/src/components/search-form/SearchForm.js +1 -1
- package/src/components/search-form/__tests__/SearchForm.test.js +25 -6
- package/src/components/sidebar-toggle-button/__tests__/__snapshots__/SidebarToggleButton.test.js.snap +4 -0
- package/src/components/table/__tests__/makeSelectable.test.js +654 -144
- package/src/components/table/makeSelectable.js +299 -98
- package/src/components/time/__tests__/ReadableTime.test.js +0 -1
- package/src/components/tooltip/Tooltip.tsx +5 -2
- package/src/components/tooltip/__tests__/Tooltip.test.tsx +10 -0
- package/src/components/tooltip/__tests__/__snapshots__/Tooltip.test.tsx.snap +1 -1
- package/src/constants.js +11 -0
- package/src/elements/common/annotator-context/__tests__/useAnnotatorEvents.test.tsx +509 -0
- package/src/elements/common/annotator-context/__tests__/withAnnotations.test.tsx +275 -12
- package/src/elements/common/annotator-context/__tests__/withAnnotatorContext.test.tsx +18 -6
- package/src/elements/common/annotator-context/index.js.flow +4 -0
- package/src/elements/common/annotator-context/index.ts +1 -0
- package/src/elements/common/annotator-context/types.js.flow +77 -35
- package/src/elements/common/annotator-context/types.ts +28 -6
- package/src/elements/common/annotator-context/useAnnotatorEvents.js.flow +52 -0
- package/src/elements/common/annotator-context/useAnnotatorEvents.ts +190 -0
- package/src/elements/common/annotator-context/withAnnotations.js.flow +73 -36
- package/src/elements/common/annotator-context/withAnnotations.tsx +170 -7
- package/src/elements/common/annotator-context/withAnnotatorContext.js.flow +29 -9
- package/src/elements/common/annotator-context/withAnnotatorContext.tsx +28 -5
- package/src/elements/common/current-user/__tests__/withCurrentUser.test.tsx +108 -0
- package/src/elements/common/current-user/index.js.flow +8 -0
- package/src/elements/common/current-user/index.ts +2 -0
- package/src/elements/common/current-user/withCurrentUser.js.flow +40 -0
- package/src/elements/common/current-user/withCurrentUser.tsx +139 -0
- package/src/elements/common/flowTypes.js +22 -4
- package/src/elements/common/interactionTargets.js +2 -0
- package/src/elements/common/logger/Logger.js +1 -1
- package/src/elements/common/messages.js +5 -0
- package/src/elements/content-explorer/DeleteConfirmationDialog.js +3 -1
- package/src/elements/content-explorer/DeleteConfirmationDialog.scss +5 -0
- package/src/elements/content-explorer/stories/DeleteConfirmationDialog.stories.js +60 -0
- package/src/elements/content-explorer/stories/DeleteConfirmationDialog.stories.md +1 -0
- package/src/elements/content-sidebar/ActivitySidebar.js +381 -154
- package/src/elements/content-sidebar/ActivitySidebarFilter.js +59 -0
- package/src/elements/content-sidebar/ActivitySidebarFilter.scss +4 -0
- package/src/elements/content-sidebar/DetailsSidebar.js +32 -4
- package/src/elements/content-sidebar/Sidebar.js +6 -1
- package/src/elements/content-sidebar/SidebarContentInsights.scss +6 -0
- package/src/elements/content-sidebar/SidebarContentInsights.tsx +57 -0
- package/src/elements/content-sidebar/SidebarPanels.js +4 -0
- package/src/elements/content-sidebar/__tests__/ActivitySidebar.test.js +533 -243
- package/src/elements/content-sidebar/__tests__/ActivitySidebarFilter.test.js +54 -0
- package/src/elements/content-sidebar/__tests__/DetailsSidebar.test.js +45 -0
- package/src/elements/content-sidebar/__tests__/Sidebar.test.js +1 -1
- package/src/elements/content-sidebar/__tests__/SidebarContentInsights.test.tsx +56 -0
- package/src/elements/content-sidebar/__tests__/SidebarPanels.test.js +4 -3
- package/src/elements/content-sidebar/__tests__/__snapshots__/ActivitySidebar.test.js.snap +29 -15
- package/src/elements/content-sidebar/__tests__/__snapshots__/SidebarFileProperties.test.js.snap +1 -0
- package/src/elements/content-sidebar/__tests__/withSidebarAnnotations.test.js +325 -32
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActiveState.js +122 -24
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityFeed.js +59 -18
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.js +126 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThread.scss +17 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.js +85 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplies.scss +16 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.js +59 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/ActivityThreadReplyForm.scss +22 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/ActiveState.test.js +19 -5
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/ActivityFeed.test.js +22 -16
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/ActivityThread.test.js +80 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/ActivityThreadReplies.test.js +24 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/ActivityThreadRepliesForm.test.js +47 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/__snapshots__/ActiveState.test.js.snap +74 -43
- package/src/elements/content-sidebar/activity-feed/activity-feed/__tests__/activityFeedUtils.test.js +8 -8
- package/src/elements/content-sidebar/activity-feed/activity-feed/activityFeedUtils.js +2 -2
- package/src/elements/content-sidebar/activity-feed/activity-feed/fixtures.ts +56 -0
- package/src/elements/content-sidebar/activity-feed/activity-feed/messages.js +20 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.js +117 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThread.scss +7 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.js +105 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadContent.scss +5 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.js +86 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/AnnotationThreadCreate.scss +3 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/__tests__/AnnotationThread.test.js +28 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/__tests__/AnnotationThreadContent.test.js +89 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/__tests__/AnnotationThreadCreate.test.js +103 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/__tests__/useAnnotationAPI.test.js +202 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/__tests__/useRepliesAPI.test.js +99 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/errors.js +26 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/index.js +1 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/messages.js +21 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/useAnnotationAPI.js +203 -0
- package/src/elements/content-sidebar/activity-feed/annotation-thread/useRepliesAPI.js +121 -0
- package/src/elements/content-sidebar/activity-feed/annotations/AnnotationActivity.js +24 -4
- package/src/elements/content-sidebar/activity-feed/annotations/AnnotationActivityMenu.js +36 -2
- package/src/elements/content-sidebar/activity-feed/annotations/__tests__/AnnotationActivity.test.js +14 -10
- package/src/elements/content-sidebar/activity-feed/annotations/__tests__/AnnotationActivityMenu.test.js +35 -1
- package/src/elements/content-sidebar/activity-feed/annotations/messages.js +10 -0
- package/src/elements/content-sidebar/activity-feed/comment/Comment.js +54 -10
- package/src/elements/content-sidebar/activity-feed/comment/__tests__/Comment.test.js +152 -7
- package/src/elements/content-sidebar/activity-feed/comment/__tests__/__snapshots__/Comment.test.js.snap +12 -7
- package/src/elements/content-sidebar/activity-feed/comment/messages.js +10 -0
- package/src/elements/content-sidebar/activity-feed/comment-form/CommentForm.js +3 -1
- package/src/elements/content-sidebar/activity-feed/comment-form/__tests__/CommentForm.test.js +11 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.js +34 -4
- package/src/elements/content-sidebar/activity-feed/common/activity-message/ActivityMessage.scss +40 -3
- package/src/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessage.js +42 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-message/CollapsableMessageToggle.js +24 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-message/__tests__/ActivityMessage.test.js +48 -1
- package/src/elements/content-sidebar/activity-feed/common/activity-message/messages.js +15 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.js +30 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-status/ActivityStatus.scss +6 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-status/__tests__/ActivityStatus.test.js +19 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-status/index.js +2 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-status/messages.js +13 -0
- package/src/elements/content-sidebar/activity-feed/common/activity-timestamp/ActivityTimestamp.scss +1 -1
- package/src/elements/content-sidebar/activity-feed/task-new/__tests__/Task.test.js +4 -3
- package/src/elements/content-sidebar/activity-feed/task-new/__tests__/__snapshots__/Task.test.js.snap +1 -2
- package/src/elements/content-sidebar/fixtures.js +185 -0
- package/src/elements/content-sidebar/flowTypes.js +9 -25
- package/src/elements/content-sidebar/messages.js +10 -0
- package/src/elements/content-sidebar/withErrorHandling.js +1 -1
- package/src/elements/content-sidebar/withSidebarAnnotations.js +162 -11
- package/src/elements/content-uploader/OverallUploadsProgressBar.js +11 -12
- package/src/features/classification/Classification.scss +1 -1
- package/src/features/classification/security-controls/SecurityControlsItem.scss +1 -0
- package/src/features/classification/security-controls/__tests__/__snapshots__/utils.test.js.snap +18 -16
- package/src/features/classification/security-controls/__tests__/utils.test.js +13 -5
- package/src/features/classification/security-controls/messages.js +10 -0
- package/src/features/classification/security-controls/utils.js +8 -12
- package/src/features/collapsible-sidebar/__tests__/__snapshots__/CollapsibleSidebarLogo.test.js.snap +2 -0
- package/src/features/content-explorer/content-explorer/ContentExplorer.js +4 -0
- package/src/features/content-explorer/content-explorer/ContentExplorer.scss +4 -0
- package/src/features/content-explorer/content-explorer/ContentExplorerBreadcrumbs.js +14 -11
- package/src/features/content-explorer/content-explorer/ContentExplorerHeaderActions.js +4 -1
- package/src/features/content-explorer/content-explorer/__tests__/ContentExplorerBreadcrumbs.test.js +2 -2
- package/src/features/content-explorer/content-explorer-modal/ContentExplorerModal.js +5 -1
- package/src/features/content-explorer/content-explorer-modal/__tests__/__snapshots__/ContentExplorerModal.test.js.snap +1 -0
- package/src/features/content-explorer/content-explorer-modal-container/ContentExplorerModalContainer.js +5 -1
- package/src/features/content-explorer/prop-types.js +8 -0
- package/src/features/content-insights/CompactCount.tsx +23 -0
- package/src/features/content-insights/ContentAnalyticsErrorState.scss +17 -0
- package/src/features/content-insights/ContentAnalyticsErrorState.tsx +44 -0
- package/src/features/content-insights/ContentInsightsSummary.scss +12 -0
- package/src/features/content-insights/ContentInsightsSummary.tsx +45 -0
- package/src/features/content-insights/ContentInsightsSummaryGhostState.scss +9 -0
- package/src/features/content-insights/ContentInsightsSummaryGhostState.tsx +18 -0
- package/src/features/content-insights/GraphCardGhostState.scss +18 -0
- package/src/features/content-insights/GraphCardGhostState.tsx +18 -0
- package/src/features/content-insights/GraphCardPreviewsSummary.scss +10 -0
- package/src/features/content-insights/GraphCardPreviewsSummary.tsx +40 -0
- package/src/features/content-insights/GraphGhostState.scss +11 -0
- package/src/features/content-insights/GraphGhostState.tsx +17 -0
- package/src/features/content-insights/HeaderWithCount.scss +10 -0
- package/src/features/content-insights/HeaderWithCount.tsx +24 -0
- package/src/features/content-insights/MetricSummary.scss +14 -0
- package/src/features/content-insights/MetricSummary.tsx +65 -0
- package/src/features/content-insights/OpenContentInsightsButton.tsx +20 -0
- package/src/features/content-insights/TrendPill.scss +33 -0
- package/src/features/content-insights/TrendPill.tsx +70 -0
- package/src/features/content-insights/__tests__/CompactCount.test.tsx +57 -0
- package/src/features/content-insights/__tests__/ContentAnalyticsErrorState.test.tsx +33 -0
- package/src/features/content-insights/__tests__/ContentInsightsSummary.test.tsx +81 -0
- package/src/features/content-insights/__tests__/GraphCardPreviewsSummary.test.tsx +35 -0
- package/src/features/content-insights/__tests__/HeaderWithCount.test.tsx +26 -0
- package/src/features/content-insights/__tests__/MetricSummary.test.tsx +88 -0
- package/src/features/content-insights/_mixins.scss +7 -0
- package/src/features/content-insights/_variables.scss +4 -0
- package/src/features/content-insights/charts/bar/Bar.scss +27 -0
- package/src/features/content-insights/charts/bar/Bar.tsx +48 -0
- package/src/features/content-insights/charts/bar/BarChart.scss +56 -0
- package/src/features/content-insights/charts/bar/BarChart.tsx +78 -0
- package/src/features/content-insights/charts/bar/__tests__/Bar.test.tsx +74 -0
- package/src/features/content-insights/charts/bar/__tests__/BarChart.test.tsx +110 -0
- package/src/features/content-insights/charts/types.ts +3 -0
- package/src/features/content-insights/constants.ts +60 -0
- package/src/features/content-insights/messages.ts +90 -0
- package/src/features/content-insights/numberUtils.ts +9 -0
- package/src/features/content-insights/types.ts +33 -0
- package/src/features/item-details/ItemProperties.scss +1 -1
- package/src/features/shared-link-settings-modal/SharedLinkSettingsModal.js +4 -2
- package/src/features/shared-link-settings-modal/__tests__/SharedLinkSettingsModal.test.js +22 -3
- package/src/features/shared-link-settings-modal/__tests__/__snapshots__/SharedLinkSettingsModal.test.js.snap +2 -1
- package/src/features/unified-share-modal/ContactRestrictionNotice.js +36 -6
- package/src/features/unified-share-modal/EmailForm.js +31 -13
- package/src/features/unified-share-modal/UnifiedShareForm.js +25 -8
- package/src/features/unified-share-modal/UnifiedShareModal.js +1 -0
- package/src/features/unified-share-modal/__tests__/ContactRestrictionNotice.test.js +55 -6
- package/src/features/unified-share-modal/__tests__/EmailForm.test.js +131 -24
- package/src/features/unified-share-modal/__tests__/UnifiedShareForm.test.js +89 -35
- package/src/features/unified-share-modal/__tests__/__snapshots__/UnifiedShareForm.test.js.snap +16 -0
- package/src/features/unified-share-modal/__tests__/__snapshots__/UnifiedShareModal.test.js.snap +17 -0
- package/src/features/unified-share-modal/flowTypes.js +4 -2
- package/src/features/unified-share-modal/messages.js +14 -8
- package/src/features/unified-share-modal/utils/__tests__/hasRestrictedContacts.test.js +24 -10
- package/src/features/unified-share-modal/utils/__tests__/isRestrictedContact.test.js +33 -0
- package/src/features/unified-share-modal/utils/hasRestrictedContacts.js +10 -3
- package/src/features/unified-share-modal/utils/isRestrictedContact.js +21 -0
- package/src/features/virtualized-table/__tests__/__snapshots__/VirtualizedTable.test.js.snap +1 -0
- package/src/icon/fill/Alert16.js.flow +3 -2
- package/src/icon/fill/Alert16.tsx +3 -2
- package/src/icon/fill/AlertBadge16.js.flow +29 -0
- package/src/icon/fill/AlertBadge16.stories.tsx +13 -0
- package/src/icon/fill/AlertBadge16.tsx +27 -0
- package/src/icon/fill/Info16.js.flow +1 -1
- package/src/icon/fill/Info16.tsx +1 -1
- package/src/icon/fill/InfoBadge16.js.flow +28 -0
- package/src/icon/fill/InfoBadge16.stories.tsx +13 -0
- package/src/icon/fill/InfoBadge16.tsx +26 -0
- package/src/icon/fill/UserSettings16.js.flow +38 -0
- package/src/icon/fill/UserSettings16.stories.tsx +13 -0
- package/src/icon/fill/UserSettings16.tsx +36 -0
- package/src/icon/line/AlertBubble16.js.flow +29 -0
- package/src/icon/line/AlertBubble16.stories.tsx +13 -0
- package/src/icon/line/AlertBubble16.tsx +27 -0
- package/src/icon/line/AvatarXBadge16.js.flow +39 -0
- package/src/icon/line/AvatarXBadge16.stories.tsx +13 -0
- package/src/icon/line/AvatarXBadge16.tsx +37 -0
- package/src/icon/line/CoEdit16.js.flow +30 -0
- package/src/icon/line/CoEdit16.stories.tsx +13 -0
- package/src/icon/line/CoEdit16.tsx +28 -0
- package/src/icon/line/Collaborations16.js.flow +30 -0
- package/src/icon/line/Collaborations16.stories.tsx +13 -0
- package/src/icon/line/Collaborations16.tsx +28 -0
- package/src/icon/line/CommentBubble16.js.flow +34 -0
- package/src/icon/line/CommentBubble16.stories.tsx +13 -0
- package/src/icon/line/CommentBubble16.tsx +32 -0
- package/src/styles/constants/_layout.scss +1 -1
- package/src/styles/constants/_media-queries.scss +2 -0
- package/src/styles/variables.js +4 -2
- package/src/styles/variables.json +4 -2
- package/src/styles/variables.ts +3 -1
- package/src/utils/__tests__/fields.test.js +23 -4
- package/src/utils/__tests__/sorter.test.js +3 -3
- package/src/utils/error.js +5 -1
- package/src/utils/fields.js +21 -3
- package/src/utils/sorter.js +2 -2
- package/es/common/types/threadedComments.js +0 -2
- package/es/common/types/threadedComments.js.flow +0 -9
- package/src/common/types/threadedComments.js +0 -9
|
@@ -2,16 +2,21 @@
|
|
|
2
2
|
import merge from 'lodash/merge';
|
|
3
3
|
import {
|
|
4
4
|
ERROR_CODE_CREATE_ANNOTATION,
|
|
5
|
+
ERROR_CODE_CREATE_REPLY,
|
|
5
6
|
ERROR_CODE_DELETE_ANNOTATION,
|
|
6
7
|
ERROR_CODE_EDIT_ANNOTATION,
|
|
7
8
|
ERROR_CODE_FETCH_ANNOTATION,
|
|
8
9
|
ERROR_CODE_FETCH_ANNOTATIONS,
|
|
10
|
+
ERROR_CODE_FETCH_REPLIES,
|
|
9
11
|
PERMISSION_CAN_CREATE_ANNOTATIONS,
|
|
10
12
|
PERMISSION_CAN_DELETE,
|
|
11
13
|
PERMISSION_CAN_EDIT,
|
|
12
14
|
PERMISSION_CAN_VIEW_ANNOTATIONS,
|
|
15
|
+
PERMISSION_CAN_RESOLVE,
|
|
13
16
|
} from '../constants';
|
|
14
17
|
import MarkerBasedApi from './MarkerBasedAPI';
|
|
18
|
+
import { formatComment } from './utils';
|
|
19
|
+
|
|
15
20
|
import type {
|
|
16
21
|
Annotation,
|
|
17
22
|
AnnotationPermission,
|
|
@@ -20,8 +25,64 @@ import type {
|
|
|
20
25
|
} from '../common/types/annotations';
|
|
21
26
|
import type { BoxItemPermission } from '../common/types/core';
|
|
22
27
|
import type { ElementsXhrError } from '../common/types/api';
|
|
28
|
+
import type { Comment, FeedItemStatus, ThreadedComments } from '../common/types/feed';
|
|
23
29
|
|
|
24
30
|
export default class Annotations extends MarkerBasedApi {
|
|
31
|
+
/**
|
|
32
|
+
* Formats annotation replies' comment data for use in components.
|
|
33
|
+
*
|
|
34
|
+
* @param {Annotation} annotation - An individual annotation entry from the API
|
|
35
|
+
* @return {Annotation} Updated annotation
|
|
36
|
+
*/
|
|
37
|
+
formatReplies(annotation: Annotation): Annotation {
|
|
38
|
+
if (!annotation.replies || !annotation.replies.length) {
|
|
39
|
+
return annotation;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return {
|
|
43
|
+
...annotation,
|
|
44
|
+
replies: annotation.replies.map(formatComment),
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Formats the annotations api response to usable data
|
|
50
|
+
* @param {Object} data the api response data
|
|
51
|
+
*/
|
|
52
|
+
successHandler = (data: Object): void => {
|
|
53
|
+
if (this.isDestroyed() || typeof this.successCallback !== 'function') {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// There is no response data when deleting an annotation
|
|
58
|
+
if (!data) {
|
|
59
|
+
this.successCallback();
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// We don't have entries when updating/creating an annotation
|
|
64
|
+
if (!data.entries) {
|
|
65
|
+
// Check if the response is a comment (result of createAnnotationReply)
|
|
66
|
+
if (data.type && data.type === 'comment') {
|
|
67
|
+
this.successCallback(formatComment(data));
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
this.successCallback(this.formatReplies(data));
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// Check if the response is the replies of an annotation (result of getAnnotationReplies)
|
|
76
|
+
if (data.entries.length && data.entries[0].type === 'comment') {
|
|
77
|
+
const replies = data.entries.map(formatComment);
|
|
78
|
+
this.successCallback({ ...data, entries: replies });
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const annotations = data.entries.map(this.formatReplies);
|
|
83
|
+
this.successCallback({ ...data, entries: annotations });
|
|
84
|
+
};
|
|
85
|
+
|
|
25
86
|
getUrl() {
|
|
26
87
|
return `${this.getBaseApiUrl()}/undoc/annotations`;
|
|
27
88
|
}
|
|
@@ -30,6 +91,10 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
30
91
|
return `${this.getUrl()}/${annotationId}`;
|
|
31
92
|
}
|
|
32
93
|
|
|
94
|
+
getUrlWithRepliesForId(annotationId: string) {
|
|
95
|
+
return `${this.getUrlForId(annotationId)}/replies`;
|
|
96
|
+
}
|
|
97
|
+
|
|
33
98
|
createAnnotation(
|
|
34
99
|
fileId: string,
|
|
35
100
|
fileVersionId: string,
|
|
@@ -55,8 +120,6 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
55
120
|
id: fileVersionId,
|
|
56
121
|
type: 'file_version',
|
|
57
122
|
},
|
|
58
|
-
status: 'open',
|
|
59
|
-
type: 'annotation',
|
|
60
123
|
};
|
|
61
124
|
|
|
62
125
|
this.post({
|
|
@@ -74,24 +137,39 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
74
137
|
fileId: string,
|
|
75
138
|
annotationId: string,
|
|
76
139
|
permissions: AnnotationPermission,
|
|
77
|
-
|
|
140
|
+
payload: { message?: string, status?: FeedItemStatus },
|
|
78
141
|
successCallback: (annotation: Annotation) => void,
|
|
79
142
|
errorCallback: (e: ElementsXhrError, code: string) => void,
|
|
80
143
|
): void {
|
|
81
144
|
this.errorCode = ERROR_CODE_EDIT_ANNOTATION;
|
|
145
|
+
const { message, status } = payload;
|
|
82
146
|
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
147
|
+
if (message) {
|
|
148
|
+
try {
|
|
149
|
+
this.checkApiCallValidity(PERMISSION_CAN_EDIT, permissions, fileId);
|
|
150
|
+
} catch (e) {
|
|
151
|
+
errorCallback(e, this.errorCode);
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
88
154
|
}
|
|
89
155
|
|
|
90
|
-
|
|
156
|
+
if (status) {
|
|
157
|
+
try {
|
|
158
|
+
this.checkApiCallValidity(PERMISSION_CAN_RESOLVE, permissions, fileId);
|
|
159
|
+
} catch (e) {
|
|
160
|
+
errorCallback(e, this.errorCode);
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
91
164
|
|
|
92
165
|
this.put({
|
|
93
166
|
id: fileId,
|
|
94
|
-
data:
|
|
167
|
+
data: {
|
|
168
|
+
data: {
|
|
169
|
+
description: message ? { message } : undefined,
|
|
170
|
+
status,
|
|
171
|
+
},
|
|
172
|
+
},
|
|
95
173
|
errorCallback,
|
|
96
174
|
successCallback,
|
|
97
175
|
url: this.getUrlForId(annotationId),
|
|
@@ -128,6 +206,7 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
128
206
|
permissions: BoxItemPermission,
|
|
129
207
|
successCallback: (annotation: Annotation) => void,
|
|
130
208
|
errorCallback: (e: ElementsXhrError, code: string) => void,
|
|
209
|
+
shouldFetchReplies?: boolean,
|
|
131
210
|
): void {
|
|
132
211
|
this.errorCode = ERROR_CODE_FETCH_ANNOTATION;
|
|
133
212
|
|
|
@@ -138,11 +217,14 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
138
217
|
return;
|
|
139
218
|
}
|
|
140
219
|
|
|
220
|
+
const requestData = shouldFetchReplies ? { params: { fields: 'replies' } } : undefined;
|
|
221
|
+
|
|
141
222
|
this.get({
|
|
142
223
|
id: fileId,
|
|
143
224
|
errorCallback,
|
|
144
225
|
successCallback,
|
|
145
226
|
url: this.getUrlForId(annotationId),
|
|
227
|
+
requestData,
|
|
146
228
|
});
|
|
147
229
|
}
|
|
148
230
|
|
|
@@ -154,6 +236,7 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
154
236
|
errorCallback: (e: ElementsXhrError, code: string) => void,
|
|
155
237
|
limit?: number,
|
|
156
238
|
shouldFetchAll?: boolean,
|
|
239
|
+
shouldFetchReplies?: boolean,
|
|
157
240
|
): void {
|
|
158
241
|
this.errorCode = ERROR_CODE_FETCH_ANNOTATIONS;
|
|
159
242
|
|
|
@@ -164,16 +247,69 @@ export default class Annotations extends MarkerBasedApi {
|
|
|
164
247
|
return;
|
|
165
248
|
}
|
|
166
249
|
|
|
250
|
+
const requestData = {
|
|
251
|
+
file_id: fileId,
|
|
252
|
+
file_version_id: fileVersionId,
|
|
253
|
+
...(shouldFetchReplies ? { fields: 'replies' } : null),
|
|
254
|
+
};
|
|
255
|
+
|
|
167
256
|
this.markerGet({
|
|
168
257
|
id: fileId,
|
|
169
258
|
errorCallback,
|
|
170
259
|
limit,
|
|
171
|
-
requestData
|
|
172
|
-
file_id: fileId,
|
|
173
|
-
file_version_id: fileVersionId,
|
|
174
|
-
},
|
|
260
|
+
requestData,
|
|
175
261
|
shouldFetchAll,
|
|
176
262
|
successCallback,
|
|
177
263
|
});
|
|
178
264
|
}
|
|
265
|
+
|
|
266
|
+
getAnnotationReplies(
|
|
267
|
+
fileId: string,
|
|
268
|
+
annotationId: string,
|
|
269
|
+
permissions: BoxItemPermission,
|
|
270
|
+
successCallback: (comments: ThreadedComments) => void,
|
|
271
|
+
errorCallback: (e: ElementsXhrError, code: string) => void,
|
|
272
|
+
): void {
|
|
273
|
+
this.errorCode = ERROR_CODE_FETCH_REPLIES;
|
|
274
|
+
|
|
275
|
+
try {
|
|
276
|
+
this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);
|
|
277
|
+
} catch (e) {
|
|
278
|
+
errorCallback(e, this.errorCode);
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
this.get({
|
|
283
|
+
id: fileId,
|
|
284
|
+
errorCallback,
|
|
285
|
+
successCallback,
|
|
286
|
+
url: this.getUrlWithRepliesForId(annotationId),
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
createAnnotationReply(
|
|
291
|
+
fileId: string,
|
|
292
|
+
annotationId: string,
|
|
293
|
+
permissions: BoxItemPermission,
|
|
294
|
+
message: string,
|
|
295
|
+
successCallback: (comment: Comment) => void,
|
|
296
|
+
errorCallback: (e: ElementsXhrError, code: string) => void,
|
|
297
|
+
): void {
|
|
298
|
+
this.errorCode = ERROR_CODE_CREATE_REPLY;
|
|
299
|
+
|
|
300
|
+
try {
|
|
301
|
+
this.checkApiCallValidity(PERMISSION_CAN_CREATE_ANNOTATIONS, permissions, fileId);
|
|
302
|
+
} catch (e) {
|
|
303
|
+
errorCallback(e, this.errorCode);
|
|
304
|
+
return;
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
this.post({
|
|
308
|
+
id: fileId,
|
|
309
|
+
data: { data: { message } },
|
|
310
|
+
errorCallback,
|
|
311
|
+
successCallback,
|
|
312
|
+
url: this.getUrlWithRepliesForId(annotationId),
|
|
313
|
+
});
|
|
314
|
+
}
|
|
179
315
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/api/Annotations.js"],"names":["merge","ERROR_CODE_CREATE_ANNOTATION","ERROR_CODE_DELETE_ANNOTATION","ERROR_CODE_EDIT_ANNOTATION","ERROR_CODE_FETCH_ANNOTATION","ERROR_CODE_FETCH_ANNOTATIONS","PERMISSION_CAN_CREATE_ANNOTATIONS","PERMISSION_CAN_DELETE","PERMISSION_CAN_EDIT","PERMISSION_CAN_VIEW_ANNOTATIONS","MarkerBasedApi","Annotations","getBaseApiUrl","annotationId","getUrl","fileId","fileVersionId","payload","permissions","successCallback","errorCallback","errorCode","checkApiCallValidity","e","defaults","description","type","file_version","id","status","post","data","url","message","requestData","put","getUrlForId","delete","get","limit","shouldFetchAll","markerGet","file_id","file_version_id"],"mappings":"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","sourcesContent":["// @flow\nimport merge from 'lodash/merge';\nimport {\n ERROR_CODE_CREATE_ANNOTATION,\n ERROR_CODE_DELETE_ANNOTATION,\n ERROR_CODE_EDIT_ANNOTATION,\n ERROR_CODE_FETCH_ANNOTATION,\n ERROR_CODE_FETCH_ANNOTATIONS,\n PERMISSION_CAN_CREATE_ANNOTATIONS,\n PERMISSION_CAN_DELETE,\n PERMISSION_CAN_EDIT,\n PERMISSION_CAN_VIEW_ANNOTATIONS,\n} from '../constants';\nimport MarkerBasedApi from './MarkerBasedAPI';\nimport type {\n Annotation,\n AnnotationPermission,\n Annotations as AnnotationsType,\n NewAnnotation,\n} from '../common/types/annotations';\nimport type { BoxItemPermission } from '../common/types/core';\nimport type { ElementsXhrError } from '../common/types/api';\n\nexport default class Annotations extends MarkerBasedApi {\n getUrl() {\n return `${this.getBaseApiUrl()}/undoc/annotations`;\n }\n\n getUrlForId(annotationId: string) {\n return `${this.getUrl()}/${annotationId}`;\n }\n\n createAnnotation(\n fileId: string,\n fileVersionId: string,\n payload: NewAnnotation,\n permissions: BoxItemPermission,\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_CREATE_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_CREATE_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const defaults = {\n description: {\n type: 'reply',\n },\n file_version: {\n id: fileVersionId,\n type: 'file_version',\n },\n status: 'open',\n type: 'annotation',\n };\n\n this.post({\n id: fileId,\n data: {\n data: merge(defaults, payload),\n },\n errorCallback,\n successCallback,\n url: this.getUrl(),\n });\n }\n\n updateAnnotation(\n fileId: string,\n annotationId: string,\n permissions: AnnotationPermission,\n message: string,\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_EDIT_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_EDIT, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = { data: { description: { message } } };\n\n this.put({\n id: fileId,\n data: requestData,\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n });\n }\n\n deleteAnnotation(\n fileId: string,\n annotationId: string,\n permissions: AnnotationPermission,\n successCallback: () => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_DELETE_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_DELETE, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.delete({\n id: fileId,\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n });\n }\n\n getAnnotation(\n fileId: string,\n annotationId: string,\n permissions: BoxItemPermission,\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.get({\n id: fileId,\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n });\n }\n\n getAnnotations(\n fileId: string,\n fileVersionId?: string,\n permissions: BoxItemPermission,\n successCallback: (annotations: AnnotationsType) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n limit?: number,\n shouldFetchAll?: boolean,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_ANNOTATIONS;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.markerGet({\n id: fileId,\n errorCallback,\n limit,\n requestData: {\n file_id: fileId,\n file_version_id: fileVersionId,\n },\n shouldFetchAll,\n successCallback,\n });\n }\n}\n"],"file":"Annotations.js"}
|
|
1
|
+
{"version":3,"sources":["../../src/api/Annotations.js"],"names":["merge","ERROR_CODE_CREATE_ANNOTATION","ERROR_CODE_CREATE_REPLY","ERROR_CODE_DELETE_ANNOTATION","ERROR_CODE_EDIT_ANNOTATION","ERROR_CODE_FETCH_ANNOTATION","ERROR_CODE_FETCH_ANNOTATIONS","ERROR_CODE_FETCH_REPLIES","PERMISSION_CAN_CREATE_ANNOTATIONS","PERMISSION_CAN_DELETE","PERMISSION_CAN_EDIT","PERMISSION_CAN_VIEW_ANNOTATIONS","PERMISSION_CAN_RESOLVE","MarkerBasedApi","formatComment","Annotations","data","isDestroyed","successCallback","entries","type","formatReplies","length","replies","map","annotations","annotation","getBaseApiUrl","annotationId","getUrl","getUrlForId","fileId","fileVersionId","payload","permissions","errorCallback","errorCode","checkApiCallValidity","e","defaults","description","file_version","id","post","url","message","status","put","undefined","delete","shouldFetchReplies","requestData","params","fields","get","limit","shouldFetchAll","file_id","file_version_id","markerGet","getUrlWithRepliesForId"],"mappings":"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","sourcesContent":["// @flow\nimport merge from 'lodash/merge';\nimport {\n ERROR_CODE_CREATE_ANNOTATION,\n ERROR_CODE_CREATE_REPLY,\n ERROR_CODE_DELETE_ANNOTATION,\n ERROR_CODE_EDIT_ANNOTATION,\n ERROR_CODE_FETCH_ANNOTATION,\n ERROR_CODE_FETCH_ANNOTATIONS,\n ERROR_CODE_FETCH_REPLIES,\n PERMISSION_CAN_CREATE_ANNOTATIONS,\n PERMISSION_CAN_DELETE,\n PERMISSION_CAN_EDIT,\n PERMISSION_CAN_VIEW_ANNOTATIONS,\n PERMISSION_CAN_RESOLVE,\n} from '../constants';\nimport MarkerBasedApi from './MarkerBasedAPI';\nimport { formatComment } from './utils';\n\nimport type {\n Annotation,\n AnnotationPermission,\n Annotations as AnnotationsType,\n NewAnnotation,\n} from '../common/types/annotations';\nimport type { BoxItemPermission } from '../common/types/core';\nimport type { ElementsXhrError } from '../common/types/api';\nimport type { Comment, FeedItemStatus, ThreadedComments } from '../common/types/feed';\n\nexport default class Annotations extends MarkerBasedApi {\n /**\n * Formats annotation replies' comment data for use in components.\n *\n * @param {Annotation} annotation - An individual annotation entry from the API\n * @return {Annotation} Updated annotation\n */\n formatReplies(annotation: Annotation): Annotation {\n if (!annotation.replies || !annotation.replies.length) {\n return annotation;\n }\n\n return {\n ...annotation,\n replies: annotation.replies.map(formatComment),\n };\n }\n\n /**\n * Formats the annotations api response to usable data\n * @param {Object} data the api response data\n */\n successHandler = (data: Object): void => {\n if (this.isDestroyed() || typeof this.successCallback !== 'function') {\n return;\n }\n\n // There is no response data when deleting an annotation\n if (!data) {\n this.successCallback();\n return;\n }\n\n // We don't have entries when updating/creating an annotation\n if (!data.entries) {\n // Check if the response is a comment (result of createAnnotationReply)\n if (data.type && data.type === 'comment') {\n this.successCallback(formatComment(data));\n return;\n }\n\n this.successCallback(this.formatReplies(data));\n return;\n }\n\n // Check if the response is the replies of an annotation (result of getAnnotationReplies)\n if (data.entries.length && data.entries[0].type === 'comment') {\n const replies = data.entries.map(formatComment);\n this.successCallback({ ...data, entries: replies });\n return;\n }\n\n const annotations = data.entries.map(this.formatReplies);\n this.successCallback({ ...data, entries: annotations });\n };\n\n getUrl() {\n return `${this.getBaseApiUrl()}/undoc/annotations`;\n }\n\n getUrlForId(annotationId: string) {\n return `${this.getUrl()}/${annotationId}`;\n }\n\n getUrlWithRepliesForId(annotationId: string) {\n return `${this.getUrlForId(annotationId)}/replies`;\n }\n\n createAnnotation(\n fileId: string,\n fileVersionId: string,\n payload: NewAnnotation,\n permissions: BoxItemPermission,\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_CREATE_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_CREATE_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const defaults = {\n description: {\n type: 'reply',\n },\n file_version: {\n id: fileVersionId,\n type: 'file_version',\n },\n };\n\n this.post({\n id: fileId,\n data: {\n data: merge(defaults, payload),\n },\n errorCallback,\n successCallback,\n url: this.getUrl(),\n });\n }\n\n updateAnnotation(\n fileId: string,\n annotationId: string,\n permissions: AnnotationPermission,\n payload: { message?: string, status?: FeedItemStatus },\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_EDIT_ANNOTATION;\n const { message, status } = payload;\n\n if (message) {\n try {\n this.checkApiCallValidity(PERMISSION_CAN_EDIT, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n }\n\n if (status) {\n try {\n this.checkApiCallValidity(PERMISSION_CAN_RESOLVE, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n }\n\n this.put({\n id: fileId,\n data: {\n data: {\n description: message ? { message } : undefined,\n status,\n },\n },\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n });\n }\n\n deleteAnnotation(\n fileId: string,\n annotationId: string,\n permissions: AnnotationPermission,\n successCallback: () => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_DELETE_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_DELETE, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.delete({\n id: fileId,\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n });\n }\n\n getAnnotation(\n fileId: string,\n annotationId: string,\n permissions: BoxItemPermission,\n successCallback: (annotation: Annotation) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n shouldFetchReplies?: boolean,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_ANNOTATION;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = shouldFetchReplies ? { params: { fields: 'replies' } } : undefined;\n\n this.get({\n id: fileId,\n errorCallback,\n successCallback,\n url: this.getUrlForId(annotationId),\n requestData,\n });\n }\n\n getAnnotations(\n fileId: string,\n fileVersionId?: string,\n permissions: BoxItemPermission,\n successCallback: (annotations: AnnotationsType) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n limit?: number,\n shouldFetchAll?: boolean,\n shouldFetchReplies?: boolean,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_ANNOTATIONS;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = {\n file_id: fileId,\n file_version_id: fileVersionId,\n ...(shouldFetchReplies ? { fields: 'replies' } : null),\n };\n\n this.markerGet({\n id: fileId,\n errorCallback,\n limit,\n requestData,\n shouldFetchAll,\n successCallback,\n });\n }\n\n getAnnotationReplies(\n fileId: string,\n annotationId: string,\n permissions: BoxItemPermission,\n successCallback: (comments: ThreadedComments) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_REPLIES;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_VIEW_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.get({\n id: fileId,\n errorCallback,\n successCallback,\n url: this.getUrlWithRepliesForId(annotationId),\n });\n }\n\n createAnnotationReply(\n fileId: string,\n annotationId: string,\n permissions: BoxItemPermission,\n message: string,\n successCallback: (comment: Comment) => void,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n ): void {\n this.errorCode = ERROR_CODE_CREATE_REPLY;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_CREATE_ANNOTATIONS, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.post({\n id: fileId,\n data: { data: { message } },\n errorCallback,\n successCallback,\n url: this.getUrlWithRepliesForId(annotationId),\n });\n }\n}\n"],"file":"Annotations.js"}
|
package/es/api/Comments.js
CHANGED
|
@@ -184,7 +184,7 @@ function (_OffsetBasedAPI) {
|
|
|
184
184
|
* @param {BoxItem} file - File object for which we are updating a comment
|
|
185
185
|
* @param {string} commentId - Comment to be edited
|
|
186
186
|
* @param {string} message - Comment message
|
|
187
|
-
* @param {
|
|
187
|
+
* @param {BoxCommentPermission} permissions - The known permissions of the comment we're updating
|
|
188
188
|
* @param {Function} successCallback - Success callback
|
|
189
189
|
* @param {Function} errorCallback - Error callback
|
|
190
190
|
* @return {void}
|
|
@@ -230,7 +230,7 @@ function (_OffsetBasedAPI) {
|
|
|
230
230
|
*
|
|
231
231
|
* @param {BoxItem} file - File object for which we are deleting a comment
|
|
232
232
|
* @param {string} commentId - Id of the comment we are deleting
|
|
233
|
-
* @param {
|
|
233
|
+
* @param {BoxCommentPermission} permissions - The known permissions of the comment we're deleting
|
|
234
234
|
* @param {Function} successCallback - Success callback
|
|
235
235
|
* @param {Function} errorCallback - Error callback
|
|
236
236
|
* @return {void}
|
package/es/api/Comments.js.flow
CHANGED
|
@@ -17,6 +17,7 @@ import {
|
|
|
17
17
|
} from '../constants';
|
|
18
18
|
import type { ElementsXhrError, ElementsErrorCallback } from '../common/types/api';
|
|
19
19
|
import type { BoxItem, BoxItemPermission } from '../common/types/core';
|
|
20
|
+
import type { BoxCommentPermission } from '../common/types/feed';
|
|
20
21
|
|
|
21
22
|
class Comments extends OffsetBasedAPI {
|
|
22
23
|
/**
|
|
@@ -144,7 +145,7 @@ class Comments extends OffsetBasedAPI {
|
|
|
144
145
|
* @param {BoxItem} file - File object for which we are updating a comment
|
|
145
146
|
* @param {string} commentId - Comment to be edited
|
|
146
147
|
* @param {string} message - Comment message
|
|
147
|
-
* @param {
|
|
148
|
+
* @param {BoxCommentPermission} permissions - The known permissions of the comment we're updating
|
|
148
149
|
* @param {Function} successCallback - Success callback
|
|
149
150
|
* @param {Function} errorCallback - Error callback
|
|
150
151
|
* @return {void}
|
|
@@ -162,7 +163,7 @@ class Comments extends OffsetBasedAPI {
|
|
|
162
163
|
errorCallback: ElementsErrorCallback,
|
|
163
164
|
file: BoxItem,
|
|
164
165
|
message: string,
|
|
165
|
-
permissions:
|
|
166
|
+
permissions: BoxCommentPermission,
|
|
166
167
|
successCallback: Function,
|
|
167
168
|
tagged_message?: string,
|
|
168
169
|
}): void {
|
|
@@ -194,7 +195,7 @@ class Comments extends OffsetBasedAPI {
|
|
|
194
195
|
*
|
|
195
196
|
* @param {BoxItem} file - File object for which we are deleting a comment
|
|
196
197
|
* @param {string} commentId - Id of the comment we are deleting
|
|
197
|
-
* @param {
|
|
198
|
+
* @param {BoxCommentPermission} permissions - The known permissions of the comment we're deleting
|
|
198
199
|
* @param {Function} successCallback - Success callback
|
|
199
200
|
* @param {Function} errorCallback - Error callback
|
|
200
201
|
* @return {void}
|
|
@@ -209,7 +210,7 @@ class Comments extends OffsetBasedAPI {
|
|
|
209
210
|
commentId: string,
|
|
210
211
|
errorCallback: ElementsErrorCallback,
|
|
211
212
|
file: BoxItem,
|
|
212
|
-
permissions:
|
|
213
|
+
permissions: BoxCommentPermission,
|
|
213
214
|
successCallback: Function,
|
|
214
215
|
}): void {
|
|
215
216
|
this.errorCode = ERROR_CODE_DELETE_COMMENT;
|
package/es/api/Comments.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/api/Comments.js"],"names":["COMMENTS_FIELDS_TO_FETCH","OffsetBasedAPI","PERMISSION_CAN_COMMENT","PERMISSION_CAN_DELETE","PERMISSION_CAN_EDIT","ERROR_CODE_CREATE_COMMENT","ERROR_CODE_UPDATE_COMMENT","ERROR_CODE_DELETE_COMMENT","ERROR_CODE_FETCH_COMMENTS","Comments","data","isDestroyed","successCallback","entries","format","comments","map","id","Error","getBaseApiUrl","baseUrl","comment","tagged_message","message","file","taggedMessage","errorCallback","errorCode","permissions","checkApiCallValidity","e","requestData","item","type","params","fields","toString","post","url","commentsUrl","commentId","put","delete","fileId","offset","limit","shouldFetchAll","offsetGet"],"mappings":"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","sourcesContent":["/**\n * @flow\n * @file Helper for the box comments API\n * @author Box\n */\n\nimport { COMMENTS_FIELDS_TO_FETCH } from '../utils/fields';\nimport OffsetBasedAPI from './OffsetBasedAPI';\nimport {\n PERMISSION_CAN_COMMENT,\n PERMISSION_CAN_DELETE,\n PERMISSION_CAN_EDIT,\n ERROR_CODE_CREATE_COMMENT,\n ERROR_CODE_UPDATE_COMMENT,\n ERROR_CODE_DELETE_COMMENT,\n ERROR_CODE_FETCH_COMMENTS,\n} from '../constants';\nimport type { ElementsXhrError, ElementsErrorCallback } from '../common/types/api';\nimport type { BoxItem, BoxItemPermission } from '../common/types/core';\n\nclass Comments extends OffsetBasedAPI {\n /**\n * API URL for comments on a file\n *\n * @param {string} id - A box file id\n * @return {string} base url for files\n */\n getUrl(id?: string): string {\n if (!id) {\n throw new Error('Missing file id!');\n }\n\n return `${this.getBaseApiUrl()}/files/${id}/comments`;\n }\n\n /**\n * API URL for comments endpoint\n *\n * @param {string} [id] - A box comment id\n * @return {string} base url for comments\n */\n commentsUrl(id?: string): string {\n const baseUrl = `${this.getBaseApiUrl()}/comments`;\n return id ? `${baseUrl}/${id}` : baseUrl;\n }\n\n /**\n * Formats comment data for use in components.\n *\n * @param {string} [id] - An individual comment entry from the API\n * @return {Task} A task\n */\n format(comment: Object): Comment {\n return {\n ...comment,\n tagged_message: comment.tagged_message !== '' ? comment.tagged_message : comment.message,\n };\n }\n\n /**\n * Formats the comments api response to usable data\n * @param {Object} data the api response data\n */\n successHandler = (data: Object): void => {\n if (this.isDestroyed() || typeof this.successCallback !== 'function') {\n return;\n }\n\n // There is no response data when deleting a comment\n if (!data) {\n this.successCallback();\n return;\n }\n\n // We don't have entries when updating/creating a comment\n if (!data.entries) {\n this.successCallback(this.format(data));\n return;\n }\n\n const comments = data.entries.map(this.format);\n this.successCallback({ ...data, entries: comments });\n };\n\n /**\n * API for creating a comment on a file\n *\n * @param {BoxItem} file - File object for which we are creating a comment\n * @param {string} message - Comment message\n * @param {string} taggedMessage - Comment message with @mentions\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n createComment({\n file,\n message,\n taggedMessage,\n successCallback,\n errorCallback,\n }: {\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n message?: string,\n successCallback: Function,\n taggedMessage?: string,\n }): void {\n this.errorCode = ERROR_CODE_CREATE_COMMENT;\n const { id = '', permissions } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_COMMENT, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = {\n data: {\n item: {\n id,\n type: 'file',\n },\n message,\n tagged_message: taggedMessage,\n },\n params: {\n fields: COMMENTS_FIELDS_TO_FETCH.toString(),\n },\n };\n\n this.post({\n id,\n url: this.commentsUrl(),\n data: requestData,\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for updating a comment on a file\n *\n * @param {BoxItem} file - File object for which we are updating a comment\n * @param {string} commentId - Comment to be edited\n * @param {string} message - Comment message\n * @param {BoxItemPermission} permissions - The known permissions of the comment we're updating\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n updateComment({\n file,\n commentId,\n message,\n tagged_message,\n permissions,\n successCallback,\n errorCallback,\n }: {\n commentId: string,\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n message: string,\n permissions: BoxItemPermission,\n successCallback: Function,\n tagged_message?: string,\n }): void {\n this.errorCode = ERROR_CODE_UPDATE_COMMENT;\n const { id = '' } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_EDIT, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = {\n data: { message, tagged_message },\n };\n\n this.put({\n id,\n url: this.commentsUrl(commentId),\n data: requestData,\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for deleting a comment on a file\n *\n * @param {BoxItem} file - File object for which we are deleting a comment\n * @param {string} commentId - Id of the comment we are deleting\n * @param {BoxItemPermission} permissions - The known permissions of the comment we're deleting\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n deleteComment({\n file,\n commentId,\n permissions,\n successCallback,\n errorCallback,\n }: {\n commentId: string,\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n permissions: BoxItemPermission,\n successCallback: Function,\n }): void {\n this.errorCode = ERROR_CODE_DELETE_COMMENT;\n const { id = '' } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_DELETE, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.delete({\n id,\n url: this.commentsUrl(commentId),\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for fetching comments on a file\n *\n * @param {string} fileId - the file id\n * @param {BoxItemPermission} permissions - the permissions for the file\n * @param {Function} successCallback - the success callback\n * @param {Function} errorCallback - the error callback\n * @param {array} fields - the fields to fetch\n * @param {number} offset - the offset from the start to start fetching at\n * @param {number} limit - the number of items to fetch\n * @param {boolean} shouldFetchAll - true if should get all the pages before calling the sucessCallback\n * @returns {void}\n */\n getComments(\n fileId: string,\n permissions: BoxItemPermission,\n successCallback: Function,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n fields: Array<string> = COMMENTS_FIELDS_TO_FETCH,\n offset?: number,\n limit?: number,\n shouldFetchAll?: boolean,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_COMMENTS;\n try {\n this.checkApiCallValidity(PERMISSION_CAN_COMMENT, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.offsetGet(fileId, successCallback, errorCallback, offset, limit, fields, shouldFetchAll);\n }\n}\n\nexport default Comments;\n"],"file":"Comments.js"}
|
|
1
|
+
{"version":3,"sources":["../../src/api/Comments.js"],"names":["COMMENTS_FIELDS_TO_FETCH","OffsetBasedAPI","PERMISSION_CAN_COMMENT","PERMISSION_CAN_DELETE","PERMISSION_CAN_EDIT","ERROR_CODE_CREATE_COMMENT","ERROR_CODE_UPDATE_COMMENT","ERROR_CODE_DELETE_COMMENT","ERROR_CODE_FETCH_COMMENTS","Comments","data","isDestroyed","successCallback","entries","format","comments","map","id","Error","getBaseApiUrl","baseUrl","comment","tagged_message","message","file","taggedMessage","errorCallback","errorCode","permissions","checkApiCallValidity","e","requestData","item","type","params","fields","toString","post","url","commentsUrl","commentId","put","delete","fileId","offset","limit","shouldFetchAll","offsetGet"],"mappings":"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","sourcesContent":["/**\n * @flow\n * @file Helper for the box comments API\n * @author Box\n */\n\nimport { COMMENTS_FIELDS_TO_FETCH } from '../utils/fields';\nimport OffsetBasedAPI from './OffsetBasedAPI';\nimport {\n PERMISSION_CAN_COMMENT,\n PERMISSION_CAN_DELETE,\n PERMISSION_CAN_EDIT,\n ERROR_CODE_CREATE_COMMENT,\n ERROR_CODE_UPDATE_COMMENT,\n ERROR_CODE_DELETE_COMMENT,\n ERROR_CODE_FETCH_COMMENTS,\n} from '../constants';\nimport type { ElementsXhrError, ElementsErrorCallback } from '../common/types/api';\nimport type { BoxItem, BoxItemPermission } from '../common/types/core';\nimport type { BoxCommentPermission } from '../common/types/feed';\n\nclass Comments extends OffsetBasedAPI {\n /**\n * API URL for comments on a file\n *\n * @param {string} id - A box file id\n * @return {string} base url for files\n */\n getUrl(id?: string): string {\n if (!id) {\n throw new Error('Missing file id!');\n }\n\n return `${this.getBaseApiUrl()}/files/${id}/comments`;\n }\n\n /**\n * API URL for comments endpoint\n *\n * @param {string} [id] - A box comment id\n * @return {string} base url for comments\n */\n commentsUrl(id?: string): string {\n const baseUrl = `${this.getBaseApiUrl()}/comments`;\n return id ? `${baseUrl}/${id}` : baseUrl;\n }\n\n /**\n * Formats comment data for use in components.\n *\n * @param {string} [id] - An individual comment entry from the API\n * @return {Task} A task\n */\n format(comment: Object): Comment {\n return {\n ...comment,\n tagged_message: comment.tagged_message !== '' ? comment.tagged_message : comment.message,\n };\n }\n\n /**\n * Formats the comments api response to usable data\n * @param {Object} data the api response data\n */\n successHandler = (data: Object): void => {\n if (this.isDestroyed() || typeof this.successCallback !== 'function') {\n return;\n }\n\n // There is no response data when deleting a comment\n if (!data) {\n this.successCallback();\n return;\n }\n\n // We don't have entries when updating/creating a comment\n if (!data.entries) {\n this.successCallback(this.format(data));\n return;\n }\n\n const comments = data.entries.map(this.format);\n this.successCallback({ ...data, entries: comments });\n };\n\n /**\n * API for creating a comment on a file\n *\n * @param {BoxItem} file - File object for which we are creating a comment\n * @param {string} message - Comment message\n * @param {string} taggedMessage - Comment message with @mentions\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n createComment({\n file,\n message,\n taggedMessage,\n successCallback,\n errorCallback,\n }: {\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n message?: string,\n successCallback: Function,\n taggedMessage?: string,\n }): void {\n this.errorCode = ERROR_CODE_CREATE_COMMENT;\n const { id = '', permissions } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_COMMENT, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = {\n data: {\n item: {\n id,\n type: 'file',\n },\n message,\n tagged_message: taggedMessage,\n },\n params: {\n fields: COMMENTS_FIELDS_TO_FETCH.toString(),\n },\n };\n\n this.post({\n id,\n url: this.commentsUrl(),\n data: requestData,\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for updating a comment on a file\n *\n * @param {BoxItem} file - File object for which we are updating a comment\n * @param {string} commentId - Comment to be edited\n * @param {string} message - Comment message\n * @param {BoxCommentPermission} permissions - The known permissions of the comment we're updating\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n updateComment({\n file,\n commentId,\n message,\n tagged_message,\n permissions,\n successCallback,\n errorCallback,\n }: {\n commentId: string,\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n message: string,\n permissions: BoxCommentPermission,\n successCallback: Function,\n tagged_message?: string,\n }): void {\n this.errorCode = ERROR_CODE_UPDATE_COMMENT;\n const { id = '' } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_EDIT, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n const requestData = {\n data: { message, tagged_message },\n };\n\n this.put({\n id,\n url: this.commentsUrl(commentId),\n data: requestData,\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for deleting a comment on a file\n *\n * @param {BoxItem} file - File object for which we are deleting a comment\n * @param {string} commentId - Id of the comment we are deleting\n * @param {BoxCommentPermission} permissions - The known permissions of the comment we're deleting\n * @param {Function} successCallback - Success callback\n * @param {Function} errorCallback - Error callback\n * @return {void}\n */\n deleteComment({\n file,\n commentId,\n permissions,\n successCallback,\n errorCallback,\n }: {\n commentId: string,\n errorCallback: ElementsErrorCallback,\n file: BoxItem,\n permissions: BoxCommentPermission,\n successCallback: Function,\n }): void {\n this.errorCode = ERROR_CODE_DELETE_COMMENT;\n const { id = '' } = file;\n\n try {\n this.checkApiCallValidity(PERMISSION_CAN_DELETE, permissions, id);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.delete({\n id,\n url: this.commentsUrl(commentId),\n successCallback,\n errorCallback,\n });\n }\n\n /**\n * API for fetching comments on a file\n *\n * @param {string} fileId - the file id\n * @param {BoxItemPermission} permissions - the permissions for the file\n * @param {Function} successCallback - the success callback\n * @param {Function} errorCallback - the error callback\n * @param {array} fields - the fields to fetch\n * @param {number} offset - the offset from the start to start fetching at\n * @param {number} limit - the number of items to fetch\n * @param {boolean} shouldFetchAll - true if should get all the pages before calling the sucessCallback\n * @returns {void}\n */\n getComments(\n fileId: string,\n permissions: BoxItemPermission,\n successCallback: Function,\n errorCallback: (e: ElementsXhrError, code: string) => void,\n fields: Array<string> = COMMENTS_FIELDS_TO_FETCH,\n offset?: number,\n limit?: number,\n shouldFetchAll?: boolean,\n ): void {\n this.errorCode = ERROR_CODE_FETCH_COMMENTS;\n try {\n this.checkApiCallValidity(PERMISSION_CAN_COMMENT, permissions, fileId);\n } catch (e) {\n errorCallback(e, this.errorCode);\n return;\n }\n\n this.offsetGet(fileId, successCallback, errorCallback, offset, limit, fields, shouldFetchAll);\n }\n}\n\nexport default Comments;\n"],"file":"Comments.js"}
|