From 64bb5a82b14b13e95128a8029aefee17d136bd08 Mon Sep 17 00:00:00 2001 From: Jake Oliver Date: Thu, 25 Apr 2024 15:09:28 -0400 Subject: [PATCH 1/2] LT-20853: Fix FocusBox word bundle elements' order --- Src/LexText/Interlinear/InterlinDocForAnalysis.cs | 7 +++++-- Src/LexText/Interlinear/SandboxBase.cs | 4 ++-- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/Src/LexText/Interlinear/InterlinDocForAnalysis.cs b/Src/LexText/Interlinear/InterlinDocForAnalysis.cs index dd66ac1729..30fe801fa4 100644 --- a/Src/LexText/Interlinear/InterlinDocForAnalysis.cs +++ b/Src/LexText/Interlinear/InterlinDocForAnalysis.cs @@ -304,7 +304,7 @@ public virtual void TriggerAnalysisSelected(AnalysisOccurrence target, bool fSav MoveFocusBoxIntoPlace(); // Now it is the right size and place we can show it. TryShowFocusBox(); - // All this CAN hapen because we're editing in another window...for example, + // All this CAN happen because we're editing in another window...for example, // if we edit something that deletes the current wordform in a concordance view. // In that case we don't want to steal the focus. if (ParentForm == Form.ActiveForm) @@ -1828,6 +1828,8 @@ internal override void UpdateForNewLineChoices(InterlinLineChoices newChoices) } } + private bool previousRightToLeft; + private bool hasRightToLeftChanged => previousRightToLeft != Vc.RightToLeft; /// /// returns the focus box for the interlinDoc if it exists or can be created. /// @@ -1835,9 +1837,10 @@ internal FocusBoxController FocusBox { get { - if (ExistingFocusBox == null && ForEditing) + if ((ExistingFocusBox == null && ForEditing) || hasRightToLeftChanged) { CreateFocusBox(); + previousRightToLeft = Vc.RightToLeft; } return ExistingFocusBox; } diff --git a/Src/LexText/Interlinear/SandboxBase.cs b/Src/LexText/Interlinear/SandboxBase.cs index e866a8e9cc..7e4f10cf53 100644 --- a/Src/LexText/Interlinear/SandboxBase.cs +++ b/Src/LexText/Interlinear/SandboxBase.cs @@ -3873,10 +3873,10 @@ public override void MakeRoot() m_dxdLayoutWidth = kForceLayout; // Don't try to draw until we get OnSize and do layout. // For some reason, we don't always initialize our control size to be the same as our rootbox. - this.Margin = new Padding(3, 0, 3, 1); + Margin = new Padding(3, 0, 3, 1); SyncControlSizeToRootBoxSize(); if (RightToLeftWritingSystem) - this.Anchor = AnchorStyles.Right | AnchorStyles.Top; + Anchor = AnchorStyles.Right | AnchorStyles.Top; //TODO: //ptmw->RegisterRootBox(qrootb); From cbde298ec06127e9f6597977e98661ee813694cf Mon Sep 17 00:00:00 2001 From: Jake Oliver Date: Fri, 26 Apr 2024 17:34:13 -0400 Subject: [PATCH 2/2] Dispose of FocusBox if it exists --- Src/LexText/Interlinear/InterlinDocForAnalysis.cs | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Src/LexText/Interlinear/InterlinDocForAnalysis.cs b/Src/LexText/Interlinear/InterlinDocForAnalysis.cs index 30fe801fa4..8cd44701cf 100644 --- a/Src/LexText/Interlinear/InterlinDocForAnalysis.cs +++ b/Src/LexText/Interlinear/InterlinDocForAnalysis.cs @@ -1852,6 +1852,11 @@ internal FocusBoxController FocusBox internal override void CreateFocusBox() { + if (ExistingFocusBox != null) + { + ExistingFocusBox.Dispose(); + } + ExistingFocusBox = CreateFocusBoxInternal(); }