From 25e346db9293bda3a1c370e5f57ac7a6bab984a2 Mon Sep 17 00:00:00 2001 From: Seraphima Zykova Date: Wed, 30 Aug 2023 17:24:19 +0300 Subject: [PATCH] [FancyZones Editor] Fix layout selection after deleting custom (#28219) --- .../Utils/FancyZonesEditorIO.cs | 49 +++++++++++++++---- 1 file changed, 39 insertions(+), 10 deletions(-) diff --git a/src/modules/fancyzones/editor/FancyZonesEditor/Utils/FancyZonesEditorIO.cs b/src/modules/fancyzones/editor/FancyZonesEditor/Utils/FancyZonesEditorIO.cs index 604c8bf33ec9..e5ecc31a5c05 100644 --- a/src/modules/fancyzones/editor/FancyZonesEditor/Utils/FancyZonesEditorIO.cs +++ b/src/modules/fancyzones/editor/FancyZonesEditor/Utils/FancyZonesEditorIO.cs @@ -1019,6 +1019,45 @@ private bool SetAppliedLayouts(List layouts) continue; } + LayoutType layoutType = JsonTagToLayoutType(layout.AppliedLayout.Type); + LayoutSettings settings = new LayoutSettings + { + ZonesetUuid = layout.AppliedLayout.Uuid, + ShowSpacing = layout.AppliedLayout.ShowSpacing, + Spacing = layout.AppliedLayout.Spacing, + Type = layoutType, + ZoneCount = layout.AppliedLayout.ZoneCount, + SensitivityRadius = layout.AppliedLayout.SensitivityRadius, + }; + + // check if the custom layout exists + bool existingLayout = layoutType != LayoutType.Custom; + if (layoutType == LayoutType.Custom) + { + foreach (LayoutModel custom in MainWindowSettingsModel.CustomModels) + { + if (custom.Uuid == layout.AppliedLayout.Uuid) + { + existingLayout = true; + break; + } + } + } + + // replace deleted layout with the Blank layout + if (!existingLayout) + { + LayoutModel blankLayout = MainWindowSettingsModel.TemplateModels[(int)LayoutType.Blank]; + settings.ZonesetUuid = blankLayout.Uuid; + settings.Type = blankLayout.Type; + settings.ZoneCount = blankLayout.TemplateZoneCount; + settings.SensitivityRadius = blankLayout.SensitivityRadius; + + // grid layout settings, just resetting them + settings.ShowSpacing = false; + settings.Spacing = 0; + } + bool unused = true; foreach (Monitor monitor in monitors) { @@ -1028,16 +1067,6 @@ private bool SetAppliedLayouts(List layouts) (monitor.Device.VirtualDesktopId == layout.Device.VirtualDesktop || layout.Device.VirtualDesktop == DefaultVirtualDesktopGuid)) { - var settings = new LayoutSettings - { - ZonesetUuid = layout.AppliedLayout.Uuid, - ShowSpacing = layout.AppliedLayout.ShowSpacing, - Spacing = layout.AppliedLayout.Spacing, - Type = JsonTagToLayoutType(layout.AppliedLayout.Type), - ZoneCount = layout.AppliedLayout.ZoneCount, - SensitivityRadius = layout.AppliedLayout.SensitivityRadius, - }; - monitor.Settings = settings; unused = false; break;