using Avalonia.Collections; namespace SourceGit.Models { public class RepositorySettings { public string DefaultRemote { get; set; } = string.Empty; public DealWithLocalChanges DealWithLocalChangesOnCheckoutBranch { get; set; } = DealWithLocalChanges.DoNothing; public bool EnablePruneOnFetch { get; set; } = false; public bool FetchWithoutTags { get; set; } = false; public DealWithLocalChanges DealWithLocalChangesOnPull { get; set; } = DealWithLocalChanges.DoNothing; public bool PreferRebaseInsteadOfMerge { get; set; } = true; public bool FetchWithoutTagsOnPull { get; set; } = false; public bool FetchAllBranchesOnPull { get; set; } = true; public bool CheckSubmodulesOnPush { get; set; } = true; public bool PushAllTags { get; set; } = false; public DealWithLocalChanges DealWithLocalChangesOnCreateBranch { get; set; } = DealWithLocalChanges.DoNothing; public bool CheckoutBranchOnCreateBranch { get; set; } = true; public AvaloniaList Filters { get; set; } = new AvaloniaList(); public AvaloniaList CommitTemplates { get; set; } = new AvaloniaList(); public AvaloniaList CommitMessages { get; set; } = new AvaloniaList(); public AvaloniaList IssueTrackerRules { get; set; } = new AvaloniaList(); public AvaloniaList CustomActions { get; set; } = new AvaloniaList(); public bool EnableAutoFetch { get; set; } = false; public int AutoFetchInterval { get; set; } = 10; public bool EnableSignOffForCommit { get; set; } = false; public bool IncludeUntrackedWhenStash { get; set; } = true; public bool OnlyStagedWhenStash { get; set; } = false; public bool KeepIndexWhenStash { get; set; } = false; public string PreferedOpenAIService { get; set; } = "---"; public void PushCommitMessage(string message) { var existIdx = CommitMessages.IndexOf(message); if (existIdx == 0) return; if (existIdx > 0) { CommitMessages.Move(existIdx, 0); return; } if (CommitMessages.Count > 9) CommitMessages.RemoveRange(9, CommitMessages.Count - 9); CommitMessages.Insert(0, message); } public IssueTrackerRule AddNewIssueTracker() { var rule = new IssueTrackerRule() { Name = "New Issue Tracker", RegexString = "#(\\d+)", URLTemplate = "https://xxx/$1", }; IssueTrackerRules.Add(rule); return rule; } public IssueTrackerRule AddGithubIssueTracker(string repoURL) { var rule = new IssueTrackerRule() { Name = "Github ISSUE", RegexString = "#(\\d+)", URLTemplate = string.IsNullOrEmpty(repoURL) ? "https://github.com/username/repository/issues/$1" : $"{repoURL}/issues/$1", }; IssueTrackerRules.Add(rule); return rule; } public IssueTrackerRule AddJiraIssueTracker() { var rule = new IssueTrackerRule() { Name = "Jira Tracker", RegexString = "PROJ-(\\d+)", URLTemplate = "https://jira.yourcompany.com/browse/PROJ-$1", }; IssueTrackerRules.Add(rule); return rule; } public IssueTrackerRule AddGitLabIssueTracker(string repoURL) { var rule = new IssueTrackerRule() { Name = "GitLab ISSUE", RegexString = "#(\\d+)", URLTemplate = string.IsNullOrEmpty(repoURL) ? "https://gitlab.com/username/repository/-/issues/$1" : $"{repoURL}/-/issues/$1", }; IssueTrackerRules.Add(rule); return rule; } public IssueTrackerRule AddGitLabMergeRequestTracker(string repoURL) { var rule = new IssueTrackerRule() { Name = "GitLab MR", RegexString = "!(\\d+)", URLTemplate = string.IsNullOrEmpty(repoURL) ? "https://gitlab.com/username/repository/-/merge_requests/$1" : $"{repoURL}/-/merge_requests/$1", }; IssueTrackerRules.Add(rule); return rule; } public void RemoveIssueTracker(IssueTrackerRule rule) { if (rule != null) IssueTrackerRules.Remove(rule); } public CustomAction AddNewCustomAction() { var act = new CustomAction() { Name = "Unnamed Custom Action", }; CustomActions.Add(act); return act; } public void RemoveCustomAction(CustomAction act) { if (act != null) CustomActions.Remove(act); } } }