From a7cdd1ee93933fefd1eb6b86939cd4c815439c36 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lukas=20D=C3=BCrrenberger?= Date: Thu, 21 Nov 2024 15:57:01 +0100 Subject: [PATCH] Filter for tasks when fetching running timers --- Clockify/ClockifyContext.cs | 29 ++++++++++++++++++----------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/Clockify/ClockifyContext.cs b/Clockify/ClockifyContext.cs index 65f47fc..b901d59 100644 --- a/Clockify/ClockifyContext.cs +++ b/Clockify/ClockifyContext.cs @@ -121,12 +121,10 @@ public async Task GetRunningTimerAsync() { return null; } - + if (string.IsNullOrEmpty(_projectName)) { - return string.IsNullOrEmpty(_timerName) - ? timeEntries.Data.FirstOrDefault() - : timeEntries.Data.FirstOrDefault(t => t.Description == _timerName); + return timeEntries.Data.FirstOrDefault(t => string.IsNullOrEmpty(_timerName) || t.Description == _timerName); } var project = await FindMatchingProjectAsync(workspace.Id); @@ -135,10 +133,12 @@ public async Task GetRunningTimerAsync() { return null; } + + var task = await FindMatchingTaskAsync(workspace.Id, project.Id, _taskName); - return string.IsNullOrEmpty(_timerName) - ? timeEntries.Data.FirstOrDefault(t => t.ProjectId == project.Id) - : timeEntries.Data.FirstOrDefault(t => t.ProjectId == project.Id && t.Description == _timerName); + return timeEntries.Data.FirstOrDefault(t => t.ProjectId == project.Id + && (string.IsNullOrEmpty(_timerName) || t.Description == _timerName) + && (string.IsNullOrEmpty(_taskName) || string.IsNullOrEmpty(task) || t.TaskId == task)); } public async Task UpdateSettings(PluginSettings settings) @@ -258,18 +258,25 @@ private async Task FindMatchingProjectAsync(string workspaceId) return project.Single(); } - private async Task FindOrCreateTaskAsync(string workspaceId, string projectId, string taskName) + private async Task FindMatchingTaskAsync(string workspaceId, string projectId, string taskName) { var taskResponse = await _clockifyClient.FindAllTasksAsync(workspaceId, projectId, name: taskName, pageSize: 5000); - if (!taskResponse.IsSuccessful || taskResponse.Data == null) + if (!taskResponse.IsSuccessful || taskResponse.Data == null || !taskResponse.Data.Any()) { return null; } - if (taskResponse.Data.Any()) + return taskResponse.Data.First().Id; + } + + private async Task FindOrCreateTaskAsync(string workspaceId, string projectId, string taskName) + { + var task = await FindMatchingTaskAsync(workspaceId, projectId, taskName); + + if (!string.IsNullOrEmpty(task)) { - return taskResponse.Data.First().Id; + return task; } var taskRequest = new TaskRequest