sfx2/source/control/recentdocsview.cxx | 1 + sfx2/source/control/recentdocsviewitem.cxx | 1 + 2 files changed, 2 insertions(+)
New commits: commit ea42621c6e8f4147827828c871046cf47ef76de8 Author: Caolán McNamara <[email protected]> AuthorDate: Thu Aug 12 16:01:51 2021 +0100 Commit: Caolán McNamara <[email protected]> CommitDate: Thu Aug 12 20:19:00 2021 +0200 Resolves: tdf#143843 disable the recently-used widget during load We show a busy-cursor but the widget can still be interacted with so another document can be launched by clicking on another recently-used item while the first one is still loading, and the recently-used widget isn't prepared for this scenario so the second to complete load will crash. Disable the recently-used widget when its cursor is set to busy, and in the (unlikely) case that the load doesn't complete normally (missing document or load filter error) and the recently-used widget still exists and its cursor is unset from busy then reenable it for user input at that point. Change-Id: I8f4487f3dbede14c9778e49442366bd9445f1d63 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/120399 Tested-by: Jenkins Reviewed-by: Caolán McNamara <[email protected]> diff --git a/sfx2/source/control/recentdocsview.cxx b/sfx2/source/control/recentdocsview.cxx index 3493df385120..c3d83741033d 100644 --- a/sfx2/source/control/recentdocsview.cxx +++ b/sfx2/source/control/recentdocsview.cxx @@ -430,6 +430,7 @@ IMPL_LINK( RecentDocsView, ExecuteHdl_Impl, void*, p, void ) { pLoadRecentFile->pView->DispatchedLoadRecentUsedFile(); pLoadRecentFile->pView->SetPointer(PointerStyle::Arrow); + pLoadRecentFile->pView->Enable(); } delete pLoadRecentFile; diff --git a/sfx2/source/control/recentdocsviewitem.cxx b/sfx2/source/control/recentdocsviewitem.cxx index e76c500ecbb0..d73b44dbd0a9 100644 --- a/sfx2/source/control/recentdocsviewitem.cxx +++ b/sfx2/source/control/recentdocsviewitem.cxx @@ -177,6 +177,7 @@ void RecentDocsViewItem::OpenDocument() { // show busy mouse pointer mrParentView.SetPointer(PointerStyle::Wait); + mrParentView.Disable(); Reference<frame::XDispatch> xDispatch; css::util::URL aTargetURL;
