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
|
@@ -1,23 +1,34 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { shallow } from 'enzyme';
|
|
3
|
-
import
|
|
2
|
+
import { shallow, mount } from 'enzyme';
|
|
3
|
+
import cloneDeep from 'lodash/cloneDeep';
|
|
4
4
|
import { ActivitySidebarComponent, activityFeedInlineError } from '../ActivitySidebar';
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
import { filterableActivityFeedItems } from '../fixtures';
|
|
6
|
+
import { FEED_ITEM_TYPE_COMMENT } from '../../../constants';
|
|
7
7
|
|
|
8
8
|
jest.mock('lodash/debounce', () => jest.fn(i => i));
|
|
9
|
+
jest.mock('lodash/uniqueId', () => () => 'uniqueId');
|
|
10
|
+
|
|
11
|
+
const userError = 'Bad box user!';
|
|
9
12
|
|
|
10
13
|
describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
11
14
|
const feedAPI = {
|
|
12
15
|
createComment: jest.fn(),
|
|
16
|
+
createReply: jest.fn(),
|
|
13
17
|
createTaskNew: jest.fn(),
|
|
18
|
+
createThreadedComment: jest.fn(),
|
|
14
19
|
deleteAnnotation: jest.fn(),
|
|
15
20
|
deleteComment: jest.fn(),
|
|
21
|
+
deleteReply: jest.fn(),
|
|
16
22
|
deleteTaskNew: jest.fn(),
|
|
23
|
+
deleteThreadedComment: jest.fn(),
|
|
17
24
|
feedItems: jest.fn(),
|
|
25
|
+
fetchReplies: jest.fn(),
|
|
18
26
|
updateAnnotation: jest.fn(),
|
|
27
|
+
updateComment: jest.fn(),
|
|
28
|
+
updateReply: jest.fn(),
|
|
19
29
|
updateTaskCollaborator: jest.fn(),
|
|
20
30
|
updateTaskNew: jest.fn(),
|
|
31
|
+
updateThreadedComment: jest.fn(),
|
|
21
32
|
};
|
|
22
33
|
const usersAPI = {
|
|
23
34
|
get: jest.fn(),
|
|
@@ -25,7 +36,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
25
36
|
getUser: jest.fn(),
|
|
26
37
|
};
|
|
27
38
|
const fileCollaboratorsAPI = {
|
|
28
|
-
|
|
39
|
+
getCollaboratorsWithQuery: jest.fn(),
|
|
29
40
|
};
|
|
30
41
|
const api = {
|
|
31
42
|
getUsersAPI: () => usersAPI,
|
|
@@ -38,8 +49,9 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
38
49
|
id: '123',
|
|
39
50
|
},
|
|
40
51
|
};
|
|
41
|
-
|
|
42
|
-
id: '
|
|
52
|
+
const currentUser = {
|
|
53
|
+
id: '123',
|
|
54
|
+
name: 'foo bar',
|
|
43
55
|
};
|
|
44
56
|
const collaborators = {
|
|
45
57
|
entries: [
|
|
@@ -55,6 +67,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
55
67
|
shallow(
|
|
56
68
|
<ActivitySidebarComponent
|
|
57
69
|
api={api}
|
|
70
|
+
currentUser={currentUser}
|
|
58
71
|
file={file}
|
|
59
72
|
logger={{ onReadyMetric: jest.fn() }}
|
|
60
73
|
onError={onError}
|
|
@@ -79,15 +92,11 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
79
92
|
describe('componentDidMount()', () => {
|
|
80
93
|
let wrapper;
|
|
81
94
|
let instance;
|
|
82
|
-
|
|
83
|
-
id: '123',
|
|
84
|
-
};
|
|
95
|
+
|
|
85
96
|
beforeEach(() => {
|
|
86
97
|
jest.spyOn(ActivitySidebarComponent.prototype, 'fetchFeedItems');
|
|
87
|
-
|
|
88
|
-
wrapper = getWrapper(
|
|
89
|
-
currentUser,
|
|
90
|
-
});
|
|
98
|
+
|
|
99
|
+
wrapper = getWrapper();
|
|
91
100
|
instance = wrapper.instance();
|
|
92
101
|
});
|
|
93
102
|
|
|
@@ -97,7 +106,6 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
97
106
|
|
|
98
107
|
test('should fetch the file and refresh the cache and fetch the current user', () => {
|
|
99
108
|
expect(instance.fetchFeedItems).toHaveBeenCalledWith(true);
|
|
100
|
-
expect(instance.fetchCurrentUser).toHaveBeenCalledWith(currentUser);
|
|
101
109
|
});
|
|
102
110
|
});
|
|
103
111
|
|
|
@@ -109,22 +117,15 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
109
117
|
});
|
|
110
118
|
|
|
111
119
|
describe('createTask()', () => {
|
|
112
|
-
let instance;
|
|
113
|
-
let wrapper;
|
|
114
|
-
|
|
115
|
-
beforeEach(() => {
|
|
116
|
-
wrapper = getWrapper();
|
|
117
|
-
instance = wrapper.instance();
|
|
118
|
-
});
|
|
119
|
-
|
|
120
120
|
test('should throw an error if there is not the current user in the state', () => {
|
|
121
|
+
const wrapper = getWrapper({ currentUser: undefined });
|
|
122
|
+
const instance = wrapper.instance();
|
|
121
123
|
expect(() => instance.createTask()).toThrow('Bad box user!');
|
|
122
124
|
});
|
|
123
125
|
|
|
124
126
|
test('should create the task and fetch the feed items', () => {
|
|
125
|
-
wrapper
|
|
126
|
-
|
|
127
|
-
});
|
|
127
|
+
const wrapper = getWrapper();
|
|
128
|
+
const instance = wrapper.instance();
|
|
128
129
|
const message = 'message';
|
|
129
130
|
const assignees = ['1', '2'];
|
|
130
131
|
const dueAt = 'test';
|
|
@@ -162,69 +163,96 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
162
163
|
});
|
|
163
164
|
|
|
164
165
|
describe('deleteComment()', () => {
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
166
|
+
test.each`
|
|
167
|
+
hasReplies
|
|
168
|
+
${undefined}
|
|
169
|
+
${false}
|
|
170
|
+
`(
|
|
171
|
+
'should call the deleteComment API if it exists when hasReplies prop equals to $hasReplies',
|
|
172
|
+
({ hasReplies }) => {
|
|
173
|
+
const wrapper = getWrapper({ hasReplies });
|
|
174
|
+
const instance = wrapper.instance();
|
|
175
|
+
instance.fetchFeedItems = jest.fn();
|
|
176
|
+
|
|
177
|
+
const id = '1';
|
|
178
|
+
const permissions = {
|
|
179
|
+
can_edit: false,
|
|
180
|
+
can_delete: true,
|
|
181
|
+
};
|
|
182
|
+
instance.deleteComment({ id, permissions });
|
|
183
|
+
expect(feedAPI.deleteComment).toBeCalledWith(
|
|
184
|
+
file,
|
|
185
|
+
id,
|
|
186
|
+
permissions,
|
|
187
|
+
expect.any(Function),
|
|
188
|
+
expect.any(Function),
|
|
189
|
+
);
|
|
190
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
191
|
+
},
|
|
192
|
+
);
|
|
193
|
+
|
|
194
|
+
test('should call the deleteThreadedComment API if it exists when hasReplies prop equals to true', () => {
|
|
195
|
+
const wrapper = getWrapper({ hasReplies: true });
|
|
196
|
+
const instance = wrapper.instance();
|
|
171
197
|
instance.fetchFeedItems = jest.fn();
|
|
172
|
-
});
|
|
173
198
|
|
|
174
|
-
test('should call the deleteComment prop if it exists', () => {
|
|
175
199
|
const id = '1';
|
|
176
200
|
const permissions = {
|
|
177
201
|
can_edit: false,
|
|
178
202
|
can_delete: true,
|
|
179
203
|
};
|
|
180
204
|
instance.deleteComment({ id, permissions });
|
|
181
|
-
expect(feedAPI.
|
|
182
|
-
|
|
205
|
+
expect(feedAPI.deleteThreadedComment).toBeCalledWith(
|
|
206
|
+
file,
|
|
207
|
+
id,
|
|
208
|
+
permissions,
|
|
209
|
+
expect.any(Function),
|
|
210
|
+
expect.any(Function),
|
|
211
|
+
);
|
|
212
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
183
213
|
});
|
|
184
214
|
});
|
|
185
215
|
|
|
186
|
-
describe('
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
instance =
|
|
192
|
-
instance.errorCallback = jest.fn();
|
|
193
|
-
});
|
|
194
|
-
test('should invoke setState() directly if user parameter is not missing', () => {
|
|
195
|
-
instance.setState = jest.fn();
|
|
196
|
-
instance.fetchCurrentUser(currentUser);
|
|
197
|
-
expect(instance.setState).toBeCalledWith({
|
|
198
|
-
currentUser,
|
|
199
|
-
currentUserError: undefined,
|
|
200
|
-
});
|
|
201
|
-
});
|
|
216
|
+
describe('deleteReply()', () => {
|
|
217
|
+
test('should call the deleteReply API and call emitAnnotationReplyDeleteEvent', () => {
|
|
218
|
+
const mockEmitAnnotationReplyDeleteEvent = jest.fn();
|
|
219
|
+
const wrapper = getWrapper({ emitAnnotationReplyDeleteEvent: mockEmitAnnotationReplyDeleteEvent });
|
|
220
|
+
const instance = wrapper.instance();
|
|
221
|
+
instance.fetchFeedItems = jest.fn();
|
|
202
222
|
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
223
|
+
const id = '1';
|
|
224
|
+
const parentId = '123';
|
|
225
|
+
const permissions = {
|
|
226
|
+
can_edit: false,
|
|
227
|
+
can_delete: true,
|
|
228
|
+
};
|
|
229
|
+
instance.deleteReply({ id, parentId, permissions });
|
|
230
|
+
expect(feedAPI.deleteReply).toBeCalledWith(
|
|
231
|
+
file,
|
|
232
|
+
id,
|
|
233
|
+
parentId,
|
|
234
|
+
permissions,
|
|
235
|
+
expect.any(Function),
|
|
236
|
+
expect.any(Function),
|
|
237
|
+
);
|
|
238
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
239
|
+
expect(mockEmitAnnotationReplyDeleteEvent).toBeCalledWith(id, parentId, true);
|
|
206
240
|
});
|
|
207
241
|
});
|
|
208
242
|
|
|
209
|
-
describe('
|
|
210
|
-
|
|
211
|
-
|
|
243
|
+
describe('deleteReplySuccessCallback()', () => {
|
|
244
|
+
test('should call the feedSuccessCallback and emitAnnotationReplyDeleteEvent', () => {
|
|
245
|
+
const mockEmitAnnotationReplyDeleteEvent = jest.fn();
|
|
246
|
+
const wrapper = getWrapper({ emitAnnotationReplyDeleteEvent: mockEmitAnnotationReplyDeleteEvent });
|
|
247
|
+
const instance = wrapper.instance();
|
|
248
|
+
instance.feedSuccessCallback = jest.fn();
|
|
212
249
|
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
instance = wrapper.instance();
|
|
216
|
-
instance.errorCallback = jest.fn();
|
|
217
|
-
instance.fetchFeedItems = jest.fn();
|
|
218
|
-
instance.fetchCurrentUser = jest.fn();
|
|
219
|
-
});
|
|
250
|
+
const id = '1';
|
|
251
|
+
const parentId = '123';
|
|
220
252
|
|
|
221
|
-
|
|
222
|
-
instance.
|
|
223
|
-
|
|
224
|
-
expect(typeof currentUserErrorHeaderMessage).toBe('object');
|
|
225
|
-
expect(typeof defaultErrorMaskSubHeaderMessage).toBe('object');
|
|
226
|
-
expect(inlineErrorState.errorHeader).toEqual(currentUserErrorHeaderMessage);
|
|
227
|
-
expect(inlineErrorState.errorSubHeader).toEqual(defaultErrorMaskSubHeaderMessage);
|
|
253
|
+
instance.deleteReplySuccessCallback(id, parentId);
|
|
254
|
+
expect(instance.feedSuccessCallback).toBeCalled();
|
|
255
|
+
expect(mockEmitAnnotationReplyDeleteEvent).toBeCalledWith(id, parentId);
|
|
228
256
|
});
|
|
229
257
|
});
|
|
230
258
|
|
|
@@ -295,7 +323,6 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
295
323
|
instance.fetchFeedItems = jest.fn();
|
|
296
324
|
instance.feedSuccessCallback = jest.fn();
|
|
297
325
|
instance.feedErrorCallback = jest.fn();
|
|
298
|
-
instance.setState({ currentUser });
|
|
299
326
|
});
|
|
300
327
|
|
|
301
328
|
test('should call the update task assignment API and fetch the items', () => {
|
|
@@ -316,27 +343,220 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
316
343
|
});
|
|
317
344
|
|
|
318
345
|
describe('createComment()', () => {
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
346
|
+
test('should throw an error if missing current user', () => {
|
|
347
|
+
const wrapper = getWrapper({ currentUser: null });
|
|
348
|
+
const instance = wrapper.instance();
|
|
349
|
+
const message = 'foo';
|
|
322
350
|
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
351
|
+
expect(() => instance.createComment(message, true)).toThrow('Bad box user!');
|
|
352
|
+
});
|
|
353
|
+
|
|
354
|
+
test.each`
|
|
355
|
+
hasReplies
|
|
356
|
+
${undefined}
|
|
357
|
+
${false}
|
|
358
|
+
`(
|
|
359
|
+
'should call the createComment API and fetch the items when hasReplies prop equals to $hasReplies',
|
|
360
|
+
({ hasReplies }) => {
|
|
361
|
+
const wrapper = getWrapper({ hasReplies });
|
|
362
|
+
const instance = wrapper.instance();
|
|
363
|
+
instance.fetchFeedItems = jest.fn();
|
|
364
|
+
const message = 'foo';
|
|
365
|
+
const hasMention = true;
|
|
366
|
+
|
|
367
|
+
instance.createComment(message, hasMention);
|
|
368
|
+
expect(feedAPI.createComment).toBeCalledWith(
|
|
369
|
+
file,
|
|
370
|
+
currentUser,
|
|
371
|
+
message,
|
|
372
|
+
hasMention,
|
|
373
|
+
expect.any(Function),
|
|
374
|
+
expect.any(Function),
|
|
375
|
+
);
|
|
376
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
377
|
+
},
|
|
378
|
+
);
|
|
379
|
+
|
|
380
|
+
test('should call the createThreadedComment API and fetch the items when hasReplies prop equals to true', () => {
|
|
381
|
+
const wrapper = getWrapper({ hasReplies: true });
|
|
382
|
+
const instance = wrapper.instance();
|
|
326
383
|
instance.fetchFeedItems = jest.fn();
|
|
384
|
+
const message = 'foo';
|
|
385
|
+
const hasMention = true;
|
|
386
|
+
|
|
387
|
+
instance.createComment(message, hasMention);
|
|
388
|
+
expect(feedAPI.createThreadedComment).toBeCalledWith(
|
|
389
|
+
file,
|
|
390
|
+
currentUser,
|
|
391
|
+
message,
|
|
392
|
+
expect.any(Function),
|
|
393
|
+
expect.any(Function),
|
|
394
|
+
);
|
|
395
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
327
396
|
});
|
|
397
|
+
});
|
|
328
398
|
|
|
399
|
+
describe('createReply()', () => {
|
|
329
400
|
test('should throw an error if missing current user', () => {
|
|
330
|
-
|
|
401
|
+
const wrapper = getWrapper({ currentUser: undefined });
|
|
402
|
+
const instance = wrapper.instance();
|
|
403
|
+
|
|
404
|
+
expect(() => instance.createReply('123', FEED_ITEM_TYPE_COMMENT, 'abc', true)).toThrow(userError);
|
|
331
405
|
});
|
|
332
406
|
|
|
333
|
-
test('should call the
|
|
407
|
+
test('should call the createReply API, fetch the items and call emitAnnotationReplyCreateEvent', () => {
|
|
408
|
+
const mockEmitAnnotationReplyCreateEvent = jest.fn();
|
|
409
|
+
const wrapper = getWrapper({ emitAnnotationReplyCreateEvent: mockEmitAnnotationReplyCreateEvent });
|
|
410
|
+
const instance = wrapper.instance();
|
|
411
|
+
instance.fetchFeedItems = jest.fn();
|
|
412
|
+
const parentId = '123';
|
|
413
|
+
const parentType = FEED_ITEM_TYPE_COMMENT;
|
|
414
|
+
const message = 'abc';
|
|
415
|
+
|
|
334
416
|
instance.setState({
|
|
335
417
|
currentUser,
|
|
336
418
|
});
|
|
337
|
-
instance.
|
|
338
|
-
expect(feedAPI.
|
|
419
|
+
instance.createReply(parentId, parentType, message);
|
|
420
|
+
expect(feedAPI.createReply).toBeCalledWith(
|
|
421
|
+
file,
|
|
422
|
+
currentUser,
|
|
423
|
+
parentId,
|
|
424
|
+
parentType,
|
|
425
|
+
message,
|
|
426
|
+
expect.any(Function),
|
|
427
|
+
expect.any(Function),
|
|
428
|
+
);
|
|
339
429
|
expect(instance.fetchFeedItems).toBeCalled();
|
|
430
|
+
expect(mockEmitAnnotationReplyCreateEvent).toBeCalledWith(
|
|
431
|
+
{ tagged_message: message },
|
|
432
|
+
'uniqueId',
|
|
433
|
+
parentId,
|
|
434
|
+
true,
|
|
435
|
+
);
|
|
436
|
+
});
|
|
437
|
+
});
|
|
438
|
+
|
|
439
|
+
describe('createReplySuccessCallback()', () => {
|
|
440
|
+
test('should call the feedSuccessCallback and emitAnnotationReplyCreateEvent', () => {
|
|
441
|
+
const mockEmitAnnotationReplyCreateEvent = jest.fn();
|
|
442
|
+
const wrapper = getWrapper({ emitAnnotationReplyCreateEvent: mockEmitAnnotationReplyCreateEvent });
|
|
443
|
+
const instance = wrapper.instance();
|
|
444
|
+
instance.feedSuccessCallback = jest.fn();
|
|
445
|
+
|
|
446
|
+
const reply = { id: '1', status: 'resolved' };
|
|
447
|
+
const parentId = '123';
|
|
448
|
+
const eventRequestId = 'comment_123';
|
|
449
|
+
|
|
450
|
+
instance.createReplySuccessCallback(eventRequestId, parentId, reply);
|
|
451
|
+
expect(instance.feedSuccessCallback).toBeCalled();
|
|
452
|
+
expect(mockEmitAnnotationReplyCreateEvent).toBeCalledWith(reply, eventRequestId, parentId);
|
|
453
|
+
});
|
|
454
|
+
});
|
|
455
|
+
|
|
456
|
+
describe('updateComment()', () => {
|
|
457
|
+
test.each`
|
|
458
|
+
hasReplies
|
|
459
|
+
${undefined}
|
|
460
|
+
${false}
|
|
461
|
+
`('should call updateComment API when hasReplies prop equals to $hasReplies', ({ hasReplies }) => {
|
|
462
|
+
const wrapper = getWrapper({ hasReplies });
|
|
463
|
+
const instance = wrapper.instance();
|
|
464
|
+
instance.fetchFeedItems = jest.fn();
|
|
465
|
+
|
|
466
|
+
wrapper.instance().updateComment('123', 'hello', undefined, false, {
|
|
467
|
+
can_edit: true,
|
|
468
|
+
can_delete: true,
|
|
469
|
+
});
|
|
470
|
+
|
|
471
|
+
expect(api.getFeedAPI().updateComment).toBeCalledWith(
|
|
472
|
+
file,
|
|
473
|
+
'123',
|
|
474
|
+
'hello',
|
|
475
|
+
false,
|
|
476
|
+
{ can_edit: true, can_delete: true },
|
|
477
|
+
expect.any(Function),
|
|
478
|
+
expect.any(Function),
|
|
479
|
+
);
|
|
480
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
481
|
+
});
|
|
482
|
+
|
|
483
|
+
describe('should call updateThreadedComment API when hasReplies prop equals to true', () => {
|
|
484
|
+
test.each`
|
|
485
|
+
status | text | expectedStatus | expectedText
|
|
486
|
+
${undefined} | ${undefined} | ${undefined} | ${undefined}
|
|
487
|
+
${'open'} | ${'foo'} | ${'open'} | ${'foo'}
|
|
488
|
+
`('given status=$status and text=$text', ({ status, text, expectedStatus, expectedText }) => {
|
|
489
|
+
const wrapper = getWrapper({ hasReplies: true });
|
|
490
|
+
const instance = wrapper.instance();
|
|
491
|
+
instance.fetchFeedItems = jest.fn();
|
|
492
|
+
|
|
493
|
+
wrapper.instance().updateComment('123', text, status, false, {
|
|
494
|
+
can_edit: true,
|
|
495
|
+
can_delete: true,
|
|
496
|
+
});
|
|
497
|
+
|
|
498
|
+
expect(api.getFeedAPI().updateThreadedComment).toBeCalledWith(
|
|
499
|
+
file,
|
|
500
|
+
'123',
|
|
501
|
+
expectedText,
|
|
502
|
+
expectedStatus,
|
|
503
|
+
{ can_edit: true, can_delete: true },
|
|
504
|
+
expect.any(Function),
|
|
505
|
+
expect.any(Function),
|
|
506
|
+
);
|
|
507
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
508
|
+
});
|
|
509
|
+
});
|
|
510
|
+
});
|
|
511
|
+
|
|
512
|
+
describe('updateReply()', () => {
|
|
513
|
+
test('should call updateReply API and call emitAnnotationReplyUpdateEvent', () => {
|
|
514
|
+
const mockEmitAnnotationReplyUpdateEvent = jest.fn();
|
|
515
|
+
const wrapper = getWrapper({ emitAnnotationReplyUpdateEvent: mockEmitAnnotationReplyUpdateEvent });
|
|
516
|
+
const instance = wrapper.instance();
|
|
517
|
+
const parentId = '123';
|
|
518
|
+
const text = 'abc';
|
|
519
|
+
const reply = {
|
|
520
|
+
id: '1',
|
|
521
|
+
permissions: { can_edit: true },
|
|
522
|
+
};
|
|
523
|
+
instance.fetchFeedItems = jest.fn();
|
|
524
|
+
|
|
525
|
+
wrapper.instance().updateReply(reply.id, parentId, text, reply.permissions);
|
|
526
|
+
|
|
527
|
+
expect(api.getFeedAPI().updateReply).toBeCalledWith(
|
|
528
|
+
file,
|
|
529
|
+
reply.id,
|
|
530
|
+
parentId,
|
|
531
|
+
text,
|
|
532
|
+
reply.permissions,
|
|
533
|
+
expect.any(Function),
|
|
534
|
+
expect.any(Function),
|
|
535
|
+
);
|
|
536
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
537
|
+
expect(mockEmitAnnotationReplyUpdateEvent).toBeCalledWith(
|
|
538
|
+
{ id: reply.id, tagged_message: text },
|
|
539
|
+
parentId,
|
|
540
|
+
true,
|
|
541
|
+
);
|
|
542
|
+
});
|
|
543
|
+
});
|
|
544
|
+
|
|
545
|
+
describe('updateReplySuccessCallback()', () => {
|
|
546
|
+
test('should call the feedSuccessCallback and emitAnnotationReplyUpdateEvent', () => {
|
|
547
|
+
const mockEmitAnnotationReplyUpdateEvent = jest.fn();
|
|
548
|
+
const wrapper = getWrapper({ emitAnnotationReplyUpdateEvent: mockEmitAnnotationReplyUpdateEvent });
|
|
549
|
+
const instance = wrapper.instance();
|
|
550
|
+
instance.feedSuccessCallback = jest.fn();
|
|
551
|
+
|
|
552
|
+
const onSuccess = jest.fn();
|
|
553
|
+
const reply = { id: '1', status: 'resolved' };
|
|
554
|
+
const parentId = '123';
|
|
555
|
+
|
|
556
|
+
instance.updateReplySuccessCallback(parentId, onSuccess, reply);
|
|
557
|
+
expect(instance.feedSuccessCallback).toBeCalled();
|
|
558
|
+
expect(mockEmitAnnotationReplyUpdateEvent).toBeCalledWith(reply, parentId);
|
|
559
|
+
expect(onSuccess).toBeCalled();
|
|
340
560
|
});
|
|
341
561
|
});
|
|
342
562
|
|
|
@@ -356,32 +576,20 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
356
576
|
});
|
|
357
577
|
|
|
358
578
|
test.each`
|
|
359
|
-
annotationsEnabled | appActivityEnabled | tasksEnabled | versionsEnabled | expectedAnnotations | expectedAppActivity | expectedTasks | expectedVersions
|
|
360
|
-
${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false}
|
|
361
|
-
${
|
|
362
|
-
${true} | ${false} | ${false} | ${true} | ${true} | ${false} | ${false} | ${true}
|
|
363
|
-
${true} | ${true} | ${false} | ${true} | ${true} | ${true} | ${false} | ${true}
|
|
364
|
-
${false} | ${true} | ${false} | ${true} | ${false} | ${true} | ${false} | ${true}
|
|
365
|
-
${false} | ${false} | ${false} | ${true} | ${false} | ${false} | ${false} | ${true}
|
|
366
|
-
${true} | ${true} | ${false} | ${false} | ${true} | ${true} | ${false} | ${false}
|
|
367
|
-
${true} | ${false} | ${false} | ${false} | ${true} | ${false} | ${false} | ${false}
|
|
368
|
-
${false} | ${false} | ${true} | ${false} | ${false} | ${false} | ${true} | ${false}
|
|
369
|
-
${false} | ${true} | ${true} | ${false} | ${false} | ${true} | ${true} | ${false}
|
|
370
|
-
${true} | ${false} | ${true} | ${true} | ${true} | ${false} | ${true} | ${true}
|
|
371
|
-
${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true}
|
|
372
|
-
${false} | ${true} | ${true} | ${true} | ${false} | ${true} | ${true} | ${true}
|
|
373
|
-
${false} | ${false} | ${true} | ${true} | ${false} | ${false} | ${true} | ${true}
|
|
374
|
-
${true} | ${true} | ${true} | ${false} | ${true} | ${true} | ${true} | ${false}
|
|
375
|
-
${true} | ${false} | ${true} | ${false} | ${true} | ${false} | ${true} | ${false}
|
|
579
|
+
annotationsEnabled | appActivityEnabled | repliesEnabled | tasksEnabled | versionsEnabled | expectedAnnotations | expectedAppActivity | expectedReplies | expectedTasks | expectedVersions
|
|
580
|
+
${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false} | ${false}
|
|
581
|
+
${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true} | ${true}
|
|
376
582
|
`(
|
|
377
|
-
'should fetch the feed items based on features: annotationsEnabled=$annotationsEnabled, appActivityEnabled=$appActivityEnabled, tasksEnabled=$tasksEnabled and versionsEnabled=$versionsEnabled',
|
|
583
|
+
'should fetch the feed items based on features: annotationsEnabled=$annotationsEnabled, appActivityEnabled=$appActivityEnabled, repliesEnabled=$repliesEnabled, tasksEnabled=$tasksEnabled and versionsEnabled=$versionsEnabled',
|
|
378
584
|
({
|
|
379
585
|
annotationsEnabled,
|
|
380
586
|
appActivityEnabled,
|
|
587
|
+
repliesEnabled,
|
|
381
588
|
tasksEnabled,
|
|
382
589
|
versionsEnabled,
|
|
383
590
|
expectedAnnotations,
|
|
384
591
|
expectedAppActivity,
|
|
592
|
+
expectedReplies,
|
|
385
593
|
expectedTasks,
|
|
386
594
|
expectedVersions,
|
|
387
595
|
}) => {
|
|
@@ -392,6 +600,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
392
600
|
appActivity: { enabled: appActivityEnabled },
|
|
393
601
|
},
|
|
394
602
|
},
|
|
603
|
+
hasReplies: repliesEnabled,
|
|
395
604
|
hasTasks: tasksEnabled,
|
|
396
605
|
hasVersions: versionsEnabled,
|
|
397
606
|
});
|
|
@@ -411,6 +620,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
411
620
|
{
|
|
412
621
|
shouldShowAnnotations: expectedAnnotations,
|
|
413
622
|
shouldShowAppActivity: expectedAppActivity,
|
|
623
|
+
shouldShowReplies: expectedReplies,
|
|
414
624
|
shouldShowTasks: expectedTasks,
|
|
415
625
|
shouldShowVersions: expectedVersions,
|
|
416
626
|
},
|
|
@@ -520,71 +730,24 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
520
730
|
});
|
|
521
731
|
});
|
|
522
732
|
|
|
523
|
-
describe('
|
|
524
|
-
let instance;
|
|
525
|
-
let wrapper;
|
|
526
|
-
|
|
527
|
-
beforeEach(() => {
|
|
528
|
-
wrapper = getWrapper();
|
|
529
|
-
instance = wrapper.instance();
|
|
530
|
-
instance.setState = jest.fn();
|
|
531
|
-
});
|
|
532
|
-
|
|
533
|
-
test('should set the feedItems in the state', () => {
|
|
534
|
-
instance.fetchCurrentUserSuccessCallback(currentUser);
|
|
535
|
-
expect(instance.setState).toBeCalledWith({
|
|
536
|
-
currentUser,
|
|
537
|
-
currentUserError: undefined,
|
|
538
|
-
});
|
|
539
|
-
});
|
|
540
|
-
});
|
|
541
|
-
|
|
542
|
-
describe('fetchCurrentUserSuccessCallback()', () => {
|
|
733
|
+
describe('getApprover()', () => {
|
|
543
734
|
let instance;
|
|
544
735
|
let wrapper;
|
|
545
736
|
|
|
546
|
-
beforeEach(() => {
|
|
547
|
-
wrapper = getWrapper();
|
|
548
|
-
instance = wrapper.instance();
|
|
549
|
-
instance.setState = jest.fn();
|
|
550
|
-
});
|
|
551
|
-
|
|
552
|
-
test('should set the feedItems in the state', () => {
|
|
553
|
-
instance.fetchCurrentUserSuccessCallback(currentUser);
|
|
554
|
-
expect(instance.setState).toBeCalledWith({
|
|
555
|
-
currentUser,
|
|
556
|
-
currentUserError: undefined,
|
|
557
|
-
});
|
|
558
|
-
});
|
|
559
|
-
});
|
|
560
|
-
|
|
561
|
-
describe('getApproverWithQuery()', () => {
|
|
562
|
-
let instance;
|
|
563
|
-
let wrapper;
|
|
564
|
-
let getCollaboratorsSpy;
|
|
565
|
-
|
|
566
737
|
test('should get collaborators with groups', () => {
|
|
567
738
|
wrapper = getWrapper();
|
|
568
739
|
instance = wrapper.instance();
|
|
569
|
-
getCollaboratorsSpy = jest.spyOn(instance, 'getCollaborators');
|
|
570
740
|
|
|
571
741
|
const search = 'Santa Claus';
|
|
572
|
-
instance.
|
|
742
|
+
instance.getApprover(search);
|
|
573
743
|
|
|
574
|
-
expect(
|
|
575
|
-
instance.getApproverContactsSuccessCallback,
|
|
576
|
-
instance.errorCallback,
|
|
577
|
-
search,
|
|
578
|
-
{ includeGroups: true },
|
|
579
|
-
);
|
|
580
|
-
expect(fileCollaboratorsAPI.getFileCollaborators).toHaveBeenCalledWith(
|
|
744
|
+
expect(api.getFileCollaboratorsAPI().getCollaboratorsWithQuery).toBeCalledWith(
|
|
581
745
|
file.id,
|
|
582
746
|
instance.getApproverContactsSuccessCallback,
|
|
583
747
|
instance.errorCallback,
|
|
748
|
+
search,
|
|
584
749
|
{
|
|
585
|
-
|
|
586
|
-
include_groups: true,
|
|
587
|
-
include_uploader_collabs: false,
|
|
750
|
+
includeGroups: true,
|
|
588
751
|
},
|
|
589
752
|
);
|
|
590
753
|
});
|
|
@@ -608,34 +771,22 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
608
771
|
});
|
|
609
772
|
});
|
|
610
773
|
|
|
611
|
-
describe('
|
|
774
|
+
describe('getMention()', () => {
|
|
612
775
|
let instance;
|
|
613
776
|
let wrapper;
|
|
614
|
-
let getCollaboratorsSpy;
|
|
615
777
|
|
|
616
|
-
|
|
778
|
+
test('should get collaborators without groups', () => {
|
|
617
779
|
wrapper = getWrapper();
|
|
618
780
|
instance = wrapper.instance();
|
|
619
|
-
getCollaboratorsSpy = jest.spyOn(instance, 'getCollaborators');
|
|
620
|
-
});
|
|
621
781
|
|
|
622
|
-
test('should get collaborators without groups', () => {
|
|
623
782
|
const search = 'Santa Claus';
|
|
624
|
-
instance.
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
instance.errorCallback,
|
|
628
|
-
search,
|
|
629
|
-
);
|
|
630
|
-
expect(fileCollaboratorsAPI.getFileCollaborators).toHaveBeenCalledWith(
|
|
783
|
+
instance.getMention(search);
|
|
784
|
+
|
|
785
|
+
expect(api.getFileCollaboratorsAPI().getCollaboratorsWithQuery).toBeCalledWith(
|
|
631
786
|
file.id,
|
|
632
787
|
instance.getMentionContactsSuccessCallback,
|
|
633
788
|
instance.errorCallback,
|
|
634
|
-
|
|
635
|
-
filter_term: search,
|
|
636
|
-
include_groups: false,
|
|
637
|
-
include_uploader_collabs: false,
|
|
638
|
-
},
|
|
789
|
+
search,
|
|
639
790
|
);
|
|
640
791
|
});
|
|
641
792
|
});
|
|
@@ -668,26 +819,24 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
668
819
|
});
|
|
669
820
|
});
|
|
670
821
|
|
|
671
|
-
describe('
|
|
672
|
-
|
|
673
|
-
|
|
822
|
+
describe('getReplies()', () => {
|
|
823
|
+
test('should call fetchReplies API', () => {
|
|
824
|
+
const wrapper = getWrapper();
|
|
825
|
+
const instance = wrapper.instance();
|
|
826
|
+
const itemId = '123';
|
|
827
|
+
const itemType = FEED_ITEM_TYPE_COMMENT;
|
|
828
|
+
instance.fetchFeedItems = jest.fn();
|
|
674
829
|
|
|
675
|
-
|
|
676
|
-
wrapper = getWrapper({
|
|
677
|
-
file,
|
|
678
|
-
});
|
|
679
|
-
instance = wrapper.instance();
|
|
680
|
-
instance.setState = jest.fn();
|
|
681
|
-
instance.errorCallback = jest.fn();
|
|
682
|
-
});
|
|
830
|
+
wrapper.instance().getReplies(itemId, itemType);
|
|
683
831
|
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
832
|
+
expect(api.getFeedAPI().fetchReplies).toBeCalledWith(
|
|
833
|
+
file,
|
|
834
|
+
itemId,
|
|
835
|
+
itemType,
|
|
836
|
+
expect.any(Function),
|
|
837
|
+
expect.any(Function),
|
|
838
|
+
);
|
|
839
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
691
840
|
});
|
|
692
841
|
});
|
|
693
842
|
|
|
@@ -709,39 +858,6 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
709
858
|
});
|
|
710
859
|
});
|
|
711
860
|
|
|
712
|
-
describe('getCollaborators()', () => {
|
|
713
|
-
let wrapper;
|
|
714
|
-
let instance;
|
|
715
|
-
let successCb;
|
|
716
|
-
let errorCb;
|
|
717
|
-
|
|
718
|
-
beforeEach(() => {
|
|
719
|
-
successCb = jest.fn();
|
|
720
|
-
errorCb = jest.fn();
|
|
721
|
-
wrapper = getWrapper({
|
|
722
|
-
file,
|
|
723
|
-
});
|
|
724
|
-
instance = wrapper.instance();
|
|
725
|
-
});
|
|
726
|
-
|
|
727
|
-
test('should short circuit if there is no search string', () => {
|
|
728
|
-
instance.getCollaborators(successCb, errorCb);
|
|
729
|
-
instance.getCollaborators(successCb, errorCb, '');
|
|
730
|
-
instance.getCollaborators(successCb, errorCb, ' ');
|
|
731
|
-
expect(fileCollaboratorsAPI.getFileCollaborators).not.toHaveBeenCalled();
|
|
732
|
-
});
|
|
733
|
-
|
|
734
|
-
test('should call the file collaborators api', () => {
|
|
735
|
-
const searchStr = 'foo';
|
|
736
|
-
instance.getCollaborators(successCb, errorCb, searchStr);
|
|
737
|
-
expect(fileCollaboratorsAPI.getFileCollaborators).toHaveBeenCalledWith(file.id, successCb, errorCb, {
|
|
738
|
-
filter_term: searchStr,
|
|
739
|
-
include_groups: false,
|
|
740
|
-
include_uploader_collabs: false,
|
|
741
|
-
});
|
|
742
|
-
});
|
|
743
|
-
});
|
|
744
|
-
|
|
745
861
|
describe('refresh()', () => {
|
|
746
862
|
let instance;
|
|
747
863
|
let wrapper;
|
|
@@ -764,7 +880,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
764
880
|
|
|
765
881
|
describe('handleAnnotationSelect()', () => {
|
|
766
882
|
const annotatorState = { activeAnnotationId: '123' };
|
|
767
|
-
const
|
|
883
|
+
const emitActiveAnnotationChangeEvent = jest.fn();
|
|
768
884
|
const getAnnotationsMatchPath = jest.fn().mockReturnValue({ params: { fileVersionId: '456' } });
|
|
769
885
|
const getAnnotationsPath = jest.fn().mockReturnValue('/activity/annotations/235/124');
|
|
770
886
|
const history = {
|
|
@@ -776,7 +892,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
776
892
|
const getAnnotationWrapper = () =>
|
|
777
893
|
getWrapper({
|
|
778
894
|
annotatorState,
|
|
779
|
-
|
|
895
|
+
emitActiveAnnotationChangeEvent,
|
|
780
896
|
file,
|
|
781
897
|
getAnnotationsMatchPath,
|
|
782
898
|
getAnnotationsPath,
|
|
@@ -791,7 +907,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
791
907
|
|
|
792
908
|
instance.handleAnnotationSelect(annotation);
|
|
793
909
|
|
|
794
|
-
expect(
|
|
910
|
+
expect(emitActiveAnnotationChangeEvent).toBeCalledWith('124');
|
|
795
911
|
expect(history.push).toHaveBeenCalledWith('/activity/annotations/235/124');
|
|
796
912
|
expect(onAnnotationSelect).toHaveBeenCalledWith(annotation);
|
|
797
913
|
});
|
|
@@ -803,7 +919,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
803
919
|
|
|
804
920
|
instance.handleAnnotationSelect(annotation);
|
|
805
921
|
|
|
806
|
-
expect(
|
|
922
|
+
expect(emitActiveAnnotationChangeEvent).toBeCalledWith('124');
|
|
807
923
|
expect(history.push).not.toHaveBeenCalled();
|
|
808
924
|
expect(onAnnotationSelect).toHaveBeenCalledWith(annotation);
|
|
809
925
|
});
|
|
@@ -816,7 +932,7 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
816
932
|
|
|
817
933
|
instance.handleAnnotationSelect(annotation);
|
|
818
934
|
|
|
819
|
-
expect(
|
|
935
|
+
expect(emitActiveAnnotationChangeEvent).toBeCalledWith('124');
|
|
820
936
|
expect(history.push).toHaveBeenCalledWith('/activity/annotations/235/124');
|
|
821
937
|
expect(onAnnotationSelect).toHaveBeenCalledWith(annotation);
|
|
822
938
|
});
|
|
@@ -829,40 +945,84 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
829
945
|
|
|
830
946
|
instance.handleAnnotationSelect(annotation);
|
|
831
947
|
|
|
832
|
-
expect(
|
|
948
|
+
expect(emitActiveAnnotationChangeEvent).toBeCalledWith('124');
|
|
833
949
|
expect(history.push).not.toHaveBeenCalled();
|
|
834
950
|
expect(onAnnotationSelect).toHaveBeenCalledWith(annotation);
|
|
835
951
|
});
|
|
836
952
|
});
|
|
837
953
|
|
|
838
954
|
describe('handleAnnotationEdit()', () => {
|
|
839
|
-
test('should call updateAnnotation API', () => {
|
|
840
|
-
const
|
|
955
|
+
test('should call updateAnnotation API and call emitAnnotationUpdateEvent', () => {
|
|
956
|
+
const mockEmitAnnotationUpdateEvent = jest.fn();
|
|
957
|
+
const wrapper = getWrapper({ emitAnnotationUpdateEvent: mockEmitAnnotationUpdateEvent });
|
|
841
958
|
const instance = wrapper.instance();
|
|
842
959
|
instance.fetchFeedItems = jest.fn();
|
|
843
960
|
|
|
844
|
-
wrapper.instance().handleAnnotationEdit({
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
961
|
+
wrapper.instance().handleAnnotationEdit('123', 'hello', {
|
|
962
|
+
can_edit: true,
|
|
963
|
+
can_delete: true,
|
|
964
|
+
can_resolve: true,
|
|
965
|
+
});
|
|
966
|
+
|
|
967
|
+
expect(mockEmitAnnotationUpdateEvent).toBeCalledWith(
|
|
968
|
+
{
|
|
969
|
+
id: '123',
|
|
970
|
+
description: {
|
|
971
|
+
message: 'hello',
|
|
972
|
+
},
|
|
850
973
|
},
|
|
974
|
+
true,
|
|
975
|
+
);
|
|
976
|
+
expect(api.getFeedAPI().updateAnnotation).toBeCalledWith(
|
|
977
|
+
expect.anything(),
|
|
978
|
+
'123',
|
|
979
|
+
'hello',
|
|
980
|
+
undefined,
|
|
981
|
+
{ can_edit: true, can_delete: true, can_resolve: true },
|
|
982
|
+
expect.any(Function),
|
|
983
|
+
expect.any(Function),
|
|
984
|
+
);
|
|
985
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
986
|
+
});
|
|
987
|
+
});
|
|
988
|
+
|
|
989
|
+
describe('handleAnnotationStatusChange()', () => {
|
|
990
|
+
test('should call updateAnnotation API and call emitAnnotationUpdateEvent', () => {
|
|
991
|
+
const mockEmitAnnotationUpdateEvent = jest.fn();
|
|
992
|
+
const wrapper = getWrapper({ emitAnnotationUpdateEvent: mockEmitAnnotationUpdateEvent });
|
|
993
|
+
const instance = wrapper.instance();
|
|
994
|
+
instance.fetchFeedItems = jest.fn();
|
|
995
|
+
|
|
996
|
+
wrapper.instance().handleAnnotationStatusChange('123', 'open', {
|
|
997
|
+
can_edit: true,
|
|
998
|
+
can_delete: true,
|
|
999
|
+
can_resolve: true,
|
|
851
1000
|
});
|
|
852
1001
|
|
|
853
|
-
expect(
|
|
854
|
-
expect(
|
|
1002
|
+
expect(mockEmitAnnotationUpdateEvent).toBeCalledWith({ id: '123', status: 'open' }, true);
|
|
1003
|
+
expect(api.getFeedAPI().updateAnnotation).toBeCalledWith(
|
|
1004
|
+
expect.anything(),
|
|
1005
|
+
'123',
|
|
1006
|
+
undefined,
|
|
1007
|
+
'open',
|
|
1008
|
+
{ can_edit: true, can_delete: true, can_resolve: true },
|
|
1009
|
+
expect.any(Function),
|
|
1010
|
+
expect.any(Function),
|
|
1011
|
+
);
|
|
1012
|
+
expect(instance.fetchFeedItems).toBeCalled();
|
|
855
1013
|
});
|
|
856
1014
|
});
|
|
857
1015
|
|
|
858
1016
|
describe('handleAnnotationDelete()', () => {
|
|
859
|
-
test('should call deleteAnnotation API', () => {
|
|
860
|
-
const
|
|
1017
|
+
test('should call deleteAnnotation API and call emitAnnotationDeleteEvent', () => {
|
|
1018
|
+
const mockEmitAnnotationRemoveEvent = jest.fn();
|
|
1019
|
+
const wrapper = getWrapper({ emitAnnotationRemoveEvent: mockEmitAnnotationRemoveEvent });
|
|
861
1020
|
const instance = wrapper.instance();
|
|
862
1021
|
instance.fetchFeedItems = jest.fn();
|
|
863
1022
|
|
|
864
1023
|
wrapper.instance().handleAnnotationDelete({ id: '123' });
|
|
865
1024
|
|
|
1025
|
+
expect(mockEmitAnnotationRemoveEvent).toBeCalledWith('123', true);
|
|
866
1026
|
expect(api.getFeedAPI().deleteAnnotation).toBeCalled();
|
|
867
1027
|
expect(instance.fetchFeedItems).toHaveBeenCalled();
|
|
868
1028
|
});
|
|
@@ -870,19 +1030,84 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
870
1030
|
|
|
871
1031
|
describe('deleteAnnotationSuccess()', () => {
|
|
872
1032
|
test('should handle successful annotation deletion', () => {
|
|
873
|
-
const
|
|
1033
|
+
const mockEmitAnnotationRemoveEvent = jest.fn();
|
|
874
1034
|
const mockFeedSuccess = jest.fn();
|
|
875
|
-
const wrapper = getWrapper({
|
|
1035
|
+
const wrapper = getWrapper({ emitAnnotationRemoveEvent: mockEmitAnnotationRemoveEvent });
|
|
876
1036
|
const instance = wrapper.instance();
|
|
877
1037
|
|
|
878
1038
|
instance.feedSuccessCallback = mockFeedSuccess;
|
|
879
1039
|
instance.deleteAnnotationSuccess('123');
|
|
880
1040
|
|
|
881
|
-
expect(
|
|
1041
|
+
expect(mockEmitAnnotationRemoveEvent).toBeCalledWith('123');
|
|
882
1042
|
expect(mockFeedSuccess).toBeCalled();
|
|
883
1043
|
});
|
|
884
1044
|
});
|
|
885
1045
|
|
|
1046
|
+
describe('getFilteredFeedItems()', () => {
|
|
1047
|
+
const {
|
|
1048
|
+
annotationOpen: expectedAnnotationOpen,
|
|
1049
|
+
annotationResolved: expectedAnnotationResolved,
|
|
1050
|
+
commentOpen: expectedCommentOpen,
|
|
1051
|
+
commentResolved: expectedCommentResolved,
|
|
1052
|
+
taskItem: expectedTaskItem,
|
|
1053
|
+
versionItem: expectedVersionItem,
|
|
1054
|
+
} = filterableActivityFeedItems;
|
|
1055
|
+
|
|
1056
|
+
test.each`
|
|
1057
|
+
status | expected
|
|
1058
|
+
${undefined} | ${[expectedAnnotationOpen, expectedAnnotationResolved, expectedCommentOpen, expectedCommentResolved, expectedTaskItem, expectedVersionItem]}
|
|
1059
|
+
${'open'} | ${[expectedAnnotationOpen, expectedCommentOpen, expectedVersionItem]}
|
|
1060
|
+
${'resolved'} | ${[expectedAnnotationResolved, expectedCommentResolved, expectedVersionItem]}
|
|
1061
|
+
`(
|
|
1062
|
+
'should filter feed items of type "comment" or "annotation" based on status equal to $status',
|
|
1063
|
+
({ status, expected }) => {
|
|
1064
|
+
const {
|
|
1065
|
+
annotationOpen,
|
|
1066
|
+
annotationResolved,
|
|
1067
|
+
commentOpen,
|
|
1068
|
+
commentResolved,
|
|
1069
|
+
taskItem,
|
|
1070
|
+
versionItem,
|
|
1071
|
+
} = cloneDeep(filterableActivityFeedItems);
|
|
1072
|
+
const wrapper = getWrapper();
|
|
1073
|
+
const instance = wrapper.instance();
|
|
1074
|
+
instance.setState({
|
|
1075
|
+
feedItems: [
|
|
1076
|
+
annotationOpen,
|
|
1077
|
+
annotationResolved,
|
|
1078
|
+
commentOpen,
|
|
1079
|
+
commentResolved,
|
|
1080
|
+
taskItem,
|
|
1081
|
+
versionItem,
|
|
1082
|
+
],
|
|
1083
|
+
});
|
|
1084
|
+
instance.setState({
|
|
1085
|
+
feedItemsStatusFilter: status,
|
|
1086
|
+
});
|
|
1087
|
+
expect(instance.getFilteredFeedItems()).toMatchObject(expected);
|
|
1088
|
+
},
|
|
1089
|
+
);
|
|
1090
|
+
});
|
|
1091
|
+
|
|
1092
|
+
describe('handleItemsFiltered()', () => {
|
|
1093
|
+
test.each`
|
|
1094
|
+
status | expected
|
|
1095
|
+
${undefined} | ${undefined}
|
|
1096
|
+
${'open'} | ${'open'}
|
|
1097
|
+
`(
|
|
1098
|
+
'given $status should update feedItemsStatusFilter state with $expected and call filter change event callback',
|
|
1099
|
+
({ status, expected }) => {
|
|
1100
|
+
const mockOnFilterChange = jest.fn();
|
|
1101
|
+
const wrapper = getWrapper({ onFilterChange: mockOnFilterChange });
|
|
1102
|
+
const instance = wrapper.instance();
|
|
1103
|
+
instance.setState = jest.fn();
|
|
1104
|
+
instance.handleItemsFiltered(status);
|
|
1105
|
+
expect(instance.setState).toBeCalledWith({ feedItemsStatusFilter: expected });
|
|
1106
|
+
expect(mockOnFilterChange).toBeCalledWith(expected);
|
|
1107
|
+
},
|
|
1108
|
+
);
|
|
1109
|
+
});
|
|
1110
|
+
|
|
886
1111
|
describe('renderAddTaskButton()', () => {
|
|
887
1112
|
test('should return null when hasTasks is false', () => {
|
|
888
1113
|
const wrapper = getWrapper({ hasTasks: false });
|
|
@@ -890,4 +1115,69 @@ describe('elements/content-sidebar/ActivitySidebar', () => {
|
|
|
890
1115
|
expect(instance.renderAddTaskButton()).toBe(null);
|
|
891
1116
|
});
|
|
892
1117
|
});
|
|
1118
|
+
|
|
1119
|
+
describe('renderActivitySidebarFilter()', () => {
|
|
1120
|
+
describe('should return null', () => {
|
|
1121
|
+
test('when activityFeed.filter feature is not set', () => {
|
|
1122
|
+
const wrapper = getWrapper();
|
|
1123
|
+
const instance = wrapper.instance();
|
|
1124
|
+
expect(instance.renderActivitySidebarFilter()).toBe(null);
|
|
1125
|
+
});
|
|
1126
|
+
|
|
1127
|
+
test('when activityFeed.filter feature is disabled', () => {
|
|
1128
|
+
const wrapper = getWrapper({
|
|
1129
|
+
features: {
|
|
1130
|
+
activityFeed: {
|
|
1131
|
+
filter: { enabled: false },
|
|
1132
|
+
},
|
|
1133
|
+
},
|
|
1134
|
+
});
|
|
1135
|
+
const instance = wrapper.instance();
|
|
1136
|
+
expect(instance.renderActivitySidebarFilter()).toBe(null);
|
|
1137
|
+
});
|
|
1138
|
+
});
|
|
1139
|
+
|
|
1140
|
+
test('should return ActivitySidebarFilter when activityFeed.filter feature is enabled', () => {
|
|
1141
|
+
const wrapper = getWrapper({
|
|
1142
|
+
features: {
|
|
1143
|
+
activityFeed: {
|
|
1144
|
+
filter: { enabled: true },
|
|
1145
|
+
},
|
|
1146
|
+
},
|
|
1147
|
+
});
|
|
1148
|
+
const instance = wrapper.instance();
|
|
1149
|
+
const resultWrapper = mount(instance.renderActivitySidebarFilter());
|
|
1150
|
+
expect(resultWrapper.name()).toBe('ActivitySidebarFilter');
|
|
1151
|
+
});
|
|
1152
|
+
});
|
|
1153
|
+
|
|
1154
|
+
describe('renderTitle()', () => {
|
|
1155
|
+
describe('should return FormattedMessage', () => {
|
|
1156
|
+
test('when activityFeed.filter feature is not set', () => {
|
|
1157
|
+
const wrapper = getWrapper();
|
|
1158
|
+
const instance = wrapper.instance();
|
|
1159
|
+
const resultWrapper = mount(instance.renderTitle());
|
|
1160
|
+
expect(resultWrapper.name()).toBe('FormattedMessage');
|
|
1161
|
+
});
|
|
1162
|
+
|
|
1163
|
+
test('when activityFeed.filter feature is disabled', () => {
|
|
1164
|
+
const wrapper = getWrapper({
|
|
1165
|
+
features: {
|
|
1166
|
+
activityFeed: {
|
|
1167
|
+
filter: { enabled: false },
|
|
1168
|
+
},
|
|
1169
|
+
},
|
|
1170
|
+
});
|
|
1171
|
+
const instance = wrapper.instance();
|
|
1172
|
+
const resultWrapper = mount(instance.renderTitle());
|
|
1173
|
+
expect(resultWrapper.name()).toBe('FormattedMessage');
|
|
1174
|
+
});
|
|
1175
|
+
});
|
|
1176
|
+
|
|
1177
|
+
test('should return undefined when activityFeed.filter feature is enabled', () => {
|
|
1178
|
+
const wrapper = getWrapper({ features: { activityFeed: { filter: { enabled: true } } } });
|
|
1179
|
+
const instance = wrapper.instance();
|
|
1180
|
+
expect(instance.renderTitle()).toBe(undefined);
|
|
1181
|
+
});
|
|
1182
|
+
});
|
|
893
1183
|
});
|