feature: allow swap in branch compare

This commit is contained in:
leo 2024-07-24 12:17:44 +08:00
parent 3ef703c65d
commit ad3eeabb83
No known key found for this signature in database
3 changed files with 60 additions and 36 deletions

View file

@ -14,14 +14,14 @@ namespace SourceGit.ViewModels
{ {
public Models.Branch Base public Models.Branch Base
{ {
get; get => _based;
private set; private set => SetProperty(ref _based, value);
} }
public Models.Branch To public Models.Branch To
{ {
get; get => _to;
private set; private set => SetProperty(ref _to, value);
} }
public Models.Commit BaseHead public Models.Commit BaseHead
@ -50,7 +50,7 @@ namespace SourceGit.ViewModels
if (SetProperty(ref _selectedChanges, value)) if (SetProperty(ref _selectedChanges, value))
{ {
if (value != null && value.Count == 1) if (value != null && value.Count == 1)
DiffContext = new DiffContext(_repo, new Models.DiffOption(Base.Head, To.Head, value[0]), _diffContext); DiffContext = new DiffContext(_repo, new Models.DiffOption(_based.Head, _to.Head, value[0]), _diffContext);
else else
DiffContext = null; DiffContext = null;
} }
@ -78,34 +78,10 @@ namespace SourceGit.ViewModels
public BranchCompare(string repo, Models.Branch baseBranch, Models.Branch toBranch) public BranchCompare(string repo, Models.Branch baseBranch, Models.Branch toBranch)
{ {
_repo = repo; _repo = repo;
_based = baseBranch;
_to = toBranch;
Base = baseBranch; Refresh();
To = toBranch;
Task.Run(() =>
{
var baseHead = new Commands.QuerySingleCommit(_repo, Base.Head).Result();
var toHead = new Commands.QuerySingleCommit(_repo, To.Head).Result();
_changes = new Commands.CompareRevisions(_repo, Base.Head, To.Head).Result();
var visible = _changes;
if (!string.IsNullOrWhiteSpace(_searchFilter))
{
visible = new List<Models.Change>();
foreach (var c in _changes)
{
if (c.Path.Contains(_searchFilter, StringComparison.OrdinalIgnoreCase))
visible.Add(c);
}
}
Dispatcher.UIThread.Invoke(() =>
{
BaseHead = baseHead;
ToHead = toHead;
VisibleChanges = visible;
});
});
} }
public void NavigateTo(string commitSHA) public void NavigateTo(string commitSHA)
@ -114,6 +90,17 @@ namespace SourceGit.ViewModels
repo?.NavigateToCommit(commitSHA); repo?.NavigateToCommit(commitSHA);
} }
public void Swap()
{
(Base, To) = (_to, _based);
SelectedChanges = [];
if (_baseHead != null)
(BaseHead, ToHead) = (_toHead, _baseHead);
Refresh();
}
public void ClearSearchFilter() public void ClearSearchFilter()
{ {
SearchFilter = string.Empty; SearchFilter = string.Empty;
@ -134,7 +121,7 @@ namespace SourceGit.ViewModels
{ {
var toolType = Preference.Instance.ExternalMergeToolType; var toolType = Preference.Instance.ExternalMergeToolType;
var toolPath = Preference.Instance.ExternalMergeToolPath; var toolPath = Preference.Instance.ExternalMergeToolPath;
var opt = new Models.DiffOption(Base.Head, To.Head, change); var opt = new Models.DiffOption(_based.Head, _to.Head, change);
Task.Run(() => Commands.MergeTool.OpenForDiff(_repo, toolType, toolPath, opt)); Task.Run(() => Commands.MergeTool.OpenForDiff(_repo, toolType, toolPath, opt));
ev.Handled = true; ev.Handled = true;
@ -179,6 +166,38 @@ namespace SourceGit.ViewModels
return menu; return menu;
} }
private void Refresh()
{
Task.Run(() =>
{
if (_baseHead == null)
{
var baseHead = new Commands.QuerySingleCommit(_repo, _based.Head).Result();
var toHead = new Commands.QuerySingleCommit(_repo, _to.Head).Result();
Dispatcher.UIThread.Invoke(() =>
{
BaseHead = baseHead;
ToHead = toHead;
});
}
_changes = new Commands.CompareRevisions(_repo, _based.Head, _to.Head).Result();
var visible = _changes;
if (!string.IsNullOrWhiteSpace(_searchFilter))
{
visible = new List<Models.Change>();
foreach (var c in _changes)
{
if (c.Path.Contains(_searchFilter, StringComparison.OrdinalIgnoreCase))
visible.Add(c);
}
}
Dispatcher.UIThread.Invoke(() => VisibleChanges = visible);
});
}
private void RefreshVisible() private void RefreshVisible()
{ {
if (_changes == null) if (_changes == null)
@ -202,6 +221,8 @@ namespace SourceGit.ViewModels
} }
private string _repo; private string _repo;
private Models.Branch _based = null;
private Models.Branch _to = null;
private Models.Commit _baseHead = null; private Models.Commit _baseHead = null;
private Models.Commit _toHead = null; private Models.Commit _toHead = null;
private List<Models.Change> _changes = null; private List<Models.Change> _changes = null;

View file

@ -69,7 +69,10 @@
</Grid> </Grid>
</Border> </Border>
<Path Grid.Column="1" Width="16" Height="16" Fill="{DynamicResource Brush.FG2}" Data="{DynamicResource Icons.Down}" RenderTransformOrigin="50%,50%" RenderTransform="rotate(270deg)"/> <!-- Swap Button -->
<Button Grid.Column="1" Classes="icon_button" Command="{Binding Swap}" HorizontalAlignment="Center" ToolTip.Tip="{DynamicResource Text.Diff.SwapCommits}">
<Path Width="16" Height="16" Fill="{DynamicResource Brush.FG2}" Data="{DynamicResource Icons.Compare}"/>
</Button>
<Border Grid.Column="2" BorderBrush="{DynamicResource Brush.Border2}" BorderThickness="1" Background="{DynamicResource Brush.Contents}" CornerRadius="4" Padding="4"> <Border Grid.Column="2" BorderBrush="{DynamicResource Brush.Border2}" BorderThickness="1" Background="{DynamicResource Brush.Contents}" CornerRadius="4" Padding="4">
<Grid RowDefinitions="Auto,*"> <Grid RowDefinitions="Auto,*">

View file

@ -47,8 +47,8 @@
</Border> </Border>
<!-- Swap Button --> <!-- Swap Button -->
<Button Classes="icon_button" Command="{Binding Swap}" Grid.Column="1" HorizontalAlignment="Center" ToolTip.Tip="{DynamicResource Text.Diff.SwapCommits}"> <Button Grid.Column="1" Classes="icon_button" Command="{Binding Swap}" HorizontalAlignment="Center" ToolTip.Tip="{DynamicResource Text.Diff.SwapCommits}">
<Path Grid.Column="1" Width="16" Height="16" Fill="{DynamicResource Brush.FG2}" Data="{DynamicResource Icons.Compare}"/> <Path Width="16" Height="16" Fill="{DynamicResource Brush.FG2}" Data="{DynamicResource Icons.Compare}"/>
</Button> </Button>
<!-- Right Revision --> <!-- Right Revision -->