diff --git a/services/web/frontend/extracted-translations.json b/services/web/frontend/extracted-translations.json index 4f3d8d97b6..1a059fe8a2 100644 --- a/services/web/frontend/extracted-translations.json +++ b/services/web/frontend/extracted-translations.json @@ -438,6 +438,7 @@ "owner": "", "page_current": "", "pagination_navigation": "", + "partial_outline_warning": "", "password": "", "password_managed_externally": "", "pdf_compile_in_progress_error": "", diff --git a/services/web/frontend/js/features/outline/components/outline-pane.js b/services/web/frontend/js/features/outline/components/outline-pane.js index 8790f3c834..6460544301 100644 --- a/services/web/frontend/js/features/outline/components/outline-pane.js +++ b/services/web/frontend/js/features/outline/components/outline-pane.js @@ -8,6 +8,7 @@ import Icon from '../../../shared/components/icon' import localStorage from '../../../infrastructure/local-storage' import withErrorBoundary from '../../../infrastructure/error-boundary' import { useProjectContext } from '../../../shared/context/project-context' +import Tooltip from '../../../shared/components/tooltip' const OutlinePane = React.memo(function OutlinePane({ isTexFile, @@ -17,6 +18,7 @@ const OutlinePane = React.memo(function OutlinePane({ eventTracking, highlightedLine, show, + isPartial = false, }) { const { t } = useTranslation() @@ -67,6 +69,20 @@ const OutlinePane = React.memo(function OutlinePane({ className="outline-caret-icon" />

{t('file_outline')}

+ {isPartial && ( + + + + + + )} {expanded && isTexFile ? ( @@ -90,6 +106,7 @@ OutlinePane.propTypes = { eventTracking: PropTypes.object.isRequired, highlightedLine: PropTypes.number, show: PropTypes.bool.isRequired, + isPartial: PropTypes.bool, } export default withErrorBoundary(OutlinePane) diff --git a/services/web/frontend/js/ide/binary-files/BinaryFilesManager.js b/services/web/frontend/js/ide/binary-files/BinaryFilesManager.js index 7345f8ba30..41d619ed7e 100644 --- a/services/web/frontend/js/ide/binary-files/BinaryFilesManager.js +++ b/services/web/frontend/js/ide/binary-files/BinaryFilesManager.js @@ -43,6 +43,7 @@ export default BinaryFilesManager = class BinaryFilesManager { this.$scope.$apply() this.$scope.$broadcast('file-view:file-opened') + window.dispatchEvent(new Event('file-view:file-opened')) }, 0, this diff --git a/services/web/frontend/stories/outline.stories.js b/services/web/frontend/stories/outline.stories.js index 3eb3c705e6..6e7db57e71 100644 --- a/services/web/frontend/stories/outline.stories.js +++ b/services/web/frontend/stories/outline.stories.js @@ -39,6 +39,11 @@ NonTexFile.args = { isTexFile: false, } +export const PartialResult = args => +PartialResult.args = { + isPartial: true, +} + export default { title: 'Editor / Outline', component: OutlinePane, diff --git a/services/web/locales/en.json b/services/web/locales/en.json index cbe8bda5aa..1b0d8dee77 100644 --- a/services/web/locales/en.json +++ b/services/web/locales/en.json @@ -76,6 +76,7 @@ "expand": "Expand", "collapse": "Collapse", "file_outline": "File outline", + "partial_outline_warning": "The File outline is out of date. It will update itself as you edit the document", "we_cant_find_any_sections_or_subsections_in_this_file": "We can’t find any sections or subsections in this file", "find_out_more_about_the_file_outline": "Find out more about the file outline", "invalid_institutional_email": "Your institution’s SSO service returned your email address as __email__, which is at an unexpected domain that we do not recognise as belonging to it. You may be able to change your primary email address via your user profile at your institution to one at your institution’s domain. Please contact your IT department if you have any questions.", diff --git a/services/web/test/frontend/features/outline/components/outline-pane.test.js b/services/web/test/frontend/features/outline/components/outline-pane.test.js index 281a5ae024..b1d41496a3 100644 --- a/services/web/test/frontend/features/outline/components/outline-pane.test.js +++ b/services/web/test/frontend/features/outline/components/outline-pane.test.js @@ -115,4 +115,35 @@ describe('', function () { expect(global.localStorage.setItem).to.be.calledWithMatch(/123abc/, 'true') expect(onToggle).to.be.calledTwice }) + + it('shows warning on partial result', function () { + render( + + ) + expect(screen.queryByRole('status')).to.exist + }) + + it('shows no warning on non-partial result', function () { + render( + + ) + + expect(screen.queryByRole('status')).to.not.exist + }) })