Skip to content

Commit

Permalink
allow internal preview when external not available
Browse files Browse the repository at this point in the history
  • Loading branch information
jjw24 committed Jun 6, 2024
1 parent 5ec474c commit 2e47da4
Showing 1 changed file with 38 additions and 24 deletions.
62 changes: 38 additions & 24 deletions Flow.Launcher/ViewModel/MainViewModel.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using System;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
Expand Down Expand Up @@ -782,19 +782,27 @@ private void ShowPreview()
{
var useExternalPreview = PluginManager.UseExternalPreview();

if (!useExternalPreview)
ShowInternalPreview();

if (useExternalPreview)
switch (useExternalPreview)
{
// Internal preview may still be on when user switches to external
if (InternalPreviewVisible)
HideInternalPreview();

if (CanExternalPreviewSelectedResult(out var path))
case true
when CanExternalPreviewSelectedResult(out var path):
// Internal preview may still be on when user switches to external
if (InternalPreviewVisible)
HideInternalPreview();
OpenExternalPreview(path);
}
break;

case true
when !CanExternalPreviewSelectedResult(out var _):
if (ExternalPreviewVisible)
CloseExternalPreview();
ShowInternalPreview();
break;

case false:
ShowInternalPreview();
break;
}
}

private void HidePreview()
Expand Down Expand Up @@ -873,27 +881,33 @@ public void ResetPreview()

private void UpdatePreview()
{
if (InternalPreviewVisible)
{
Results.SelectedItem?.LoadPreviewImage();
return;
}

switch (PluginManager.UseExternalPreview())
{
case true
when ExternalPreviewVisible && CanExternalPreviewSelectedResult(out var path):
SwitchExternalPreview(path, false);
when CanExternalPreviewSelectedResult(out var path):
if (ExternalPreviewVisible)
{
SwitchExternalPreview(path, false);
}
else if (InternalPreviewVisible)
{
HideInternalPreview();
OpenExternalPreview(path);
}
break;

case true
when !ExternalPreviewVisible && Settings.AlwaysPreview && CanExternalPreviewSelectedResult(out var _):
ShowPreview();
when !CanExternalPreviewSelectedResult(out var _):
if (ExternalPreviewVisible)
{
CloseExternalPreview();
ShowInternalPreview();
}
break;

case true
when !CanExternalPreviewSelectedResult(out var _):
HidePreview();
case false
when InternalPreviewVisible:
Results.SelectedItem?.LoadPreviewImage();
break;
}
}
Expand Down

0 comments on commit 2e47da4

Please sign in to comment.