diff --git a/src/Files.App/Data/Contracts/IShellPanesPage.cs b/src/Files.App/Data/Contracts/IShellPanesPage.cs
index f6b068ffe883..5b5730be3055 100644
--- a/src/Files.App/Data/Contracts/IShellPanesPage.cs
+++ b/src/Files.App/Data/Contracts/IShellPanesPage.cs
@@ -62,6 +62,6 @@ public interface IShellPanesPage : IDisposable, INotifyPropertyChanged
///
/// Updates the layout of open panes.
///
- public void UpdatePanesLayout(bool inlcudeActive = true);
+ public void UpdatePanesLayout();
}
}
diff --git a/src/Files.App/Views/ShellPanesPage.xaml.cs b/src/Files.App/Views/ShellPanesPage.xaml.cs
index cce04ae03630..6754f738b8d1 100644
--- a/src/Files.App/Views/ShellPanesPage.xaml.cs
+++ b/src/Files.App/Views/ShellPanesPage.xaml.cs
@@ -19,6 +19,7 @@ public sealed partial class ShellPanesPage : Page, IShellPanesPage, ITabBarItemC
// Dependency injections
private IGeneralSettingsService GeneralSettingsService { get; } = Ioc.Default.GetRequiredService();
+ private ILayoutSettingsService LayoutSettingsService { get; } = Ioc.Default.GetRequiredService();
private AppModel AppModel { get; } = Ioc.Default.GetRequiredService();
// Constants
@@ -357,13 +358,10 @@ public void FocusOtherPane()
}
///
- public void UpdatePanesLayout(bool inlcudeActive = true)
+ public void UpdatePanesLayout()
{
- if (GetPane(0) is IShellPage leftPane && (inlcudeActive || leftPane != ActivePane))
- UpdatePaneLayout(leftPane);
-
- if (GetPane(1) is IShellPage rightPane && (inlcudeActive || rightPane != ActivePane))
- UpdatePaneLayout(rightPane);
+ foreach (var pane in GetPanes())
+ UpdatePaneLayout(pane);
}
// Private methods
@@ -469,6 +467,9 @@ RootGrid.ColumnDefinitions.Count is 0
// Focus
ActivePane = GetPane(GetPaneCount() - 1);
+ UnHookLayoutUpdateRequiredEvent();
+ HookLayoutUpdateRequiredEvent();
+
NotifyPropertyChanged(nameof(IsMultiPaneActive));
}
@@ -533,6 +534,7 @@ private void RemovePane(int index = -1)
}
Pane_ContentChanged(null, null!);
+ UnHookLayoutUpdateRequiredEvent();
NotifyPropertyChanged(nameof(IsMultiPaneActive));
}
@@ -562,6 +564,18 @@ private void SetShadow()
}
}
+ private void HookLayoutUpdateRequiredEvent()
+ {
+ foreach (var pane in GetPanes())
+ pane.FolderSettings.LayoutPreferencesUpdateRequired += FolderSettings_LayoutPreferencesUpdateRequired;
+ }
+
+ private void UnHookLayoutUpdateRequiredEvent()
+ {
+ foreach (var pane in GetPanes())
+ pane.FolderSettings.LayoutPreferencesUpdateRequired -= FolderSettings_LayoutPreferencesUpdateRequired;
+ }
+
// Override methods
protected override void OnNavigatedTo(NavigationEventArgs eventArgs)
@@ -741,6 +755,24 @@ private void Sizer_ManipulationCompleted(object sender, ManipulationCompletedRou
this.ChangeCursor(InputSystemCursor.Create(InputSystemCursorShape.Arrow));
}
+ private void FolderSettings_LayoutPreferencesUpdateRequired(object? sender, LayoutPreferenceEventArgs e)
+ {
+ var currentPath = ActivePane?.TabBarItemParameter?.NavigationParameter as string;
+ if (string.IsNullOrEmpty(currentPath))
+ return;
+
+ foreach (var pane in GetPanes())
+ {
+ if (pane != ActivePane &&
+ (LayoutSettingsService.SyncFolderPreferencesAcrossDirectories ||
+ pane.TabBarItemParameter?.NavigationParameter is string path &&
+ path.Equals(currentPath, StringComparison.OrdinalIgnoreCase)))
+ {
+ UpdatePaneLayout(pane);
+ }
+ }
+ }
+
private void NotifyPropertyChanged([CallerMemberName] string propertyName = "")
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
@@ -760,6 +792,7 @@ public void Dispose()
pane.GotFocus -= Pane_GotFocus;
pane.RightTapped -= Pane_RightTapped;
pane.PointerPressed -= Pane_PointerPressed;
+ pane.FolderSettings.LayoutPreferencesUpdateRequired -= FolderSettings_LayoutPreferencesUpdateRequired;
pane.Dispose();
}
diff --git a/src/Files.App/Views/Shells/BaseShellPage.cs b/src/Files.App/Views/Shells/BaseShellPage.cs
index 64fa8d472d08..305c8d211aa4 100644
--- a/src/Files.App/Views/Shells/BaseShellPage.cs
+++ b/src/Files.App/Views/Shells/BaseShellPage.cs
@@ -707,8 +707,6 @@ private void FolderSettings_LayoutPreferencesUpdateRequired(object sender, Layou
LayoutPreferencesManager.SetLayoutPreferencesForPath(ShellViewModel.WorkingDirectory, e.LayoutPreference);
if (e.IsAdaptiveLayoutUpdateRequired)
AdaptiveLayoutHelpers.ApplyAdaptativeLayout(InstanceViewModel.FolderSettings, ShellViewModel.FilesAndFolders.ToList());
-
- _PaneHolder.UpdatePanesLayout(false);
}
protected virtual void ViewModel_WorkingDirectoryModified(object sender, WorkingDirectoryModifiedEventArgs e)