fix-issue-81 #88

Merged
sebastian merged 3 commits from fix-issue-81 into master 2023-12-20 09:54:27 +00:00
5 changed files with 55 additions and 7 deletions

View File

@ -3,10 +3,7 @@ package core.api.controller;
import core.api.models.auth.SimpleStatusResponse; import core.api.models.auth.SimpleStatusResponse;
import core.api.models.timemanager.taskSchedule.*; import core.api.models.timemanager.taskSchedule.*;
import core.api.models.timemanager.taskSchedule.scheduleInfos.AdvancedScheduleFieldInfo; import core.api.models.timemanager.taskSchedule.scheduleInfos.*;
import core.api.models.timemanager.taskSchedule.scheduleInfos.AdvancedScheduleInfo;
import core.api.models.timemanager.taskSchedule.scheduleInfos.BasicScheduleFieldInfo;
import core.api.models.timemanager.taskSchedule.scheduleInfos.ScheduleFieldInfo;
import core.entities.timemanager.AbstractSchedule; import core.entities.timemanager.AbstractSchedule;
import core.entities.timemanager.AdvancedTaskSchedule; import core.entities.timemanager.AdvancedTaskSchedule;
import core.entities.timemanager.BasicTaskSchedule; import core.entities.timemanager.BasicTaskSchedule;
@ -50,7 +47,14 @@ public class ScheduleController {
} }
List<AbstractSchedule> taskSchedules = permissionResult.getResult().getBasicTaskSchedules(); List<AbstractSchedule> taskSchedules = permissionResult.getResult().getBasicTaskSchedules();
return ResponseEntity.ok(taskSchedules.stream().map(AbstractSchedule::toScheduleInfo).toList()); List<ScheduleInfo> scheduleInfos = new ArrayList<>();
for(AbstractSchedule schedule : taskSchedules) {
//Filter completed schedules out
if(!schedule.isCompleted()) {
scheduleInfos.add(schedule.toScheduleInfo());
}
}
return ResponseEntity.ok(scheduleInfos);
} }
@PutMapping("/schedules/{taskID}/basic") @PutMapping("/schedules/{taskID}/basic")

View File

@ -207,4 +207,8 @@ public class Task {
} }
return false; return false;
} }
public void increaseWorkTime(long minutes) {
this.workTime += (int) minutes;
}
} }

View File

@ -14,6 +14,7 @@ import core.repositories.timemanager.TaskRepository;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import java.time.Duration;
import java.time.LocalDate; import java.time.LocalDate;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.ArrayList; import java.util.ArrayList;
@ -164,6 +165,9 @@ public class TaskScheduleService {
if(schedule.getStartTime() != null && schedule.getStopTime() == null) { if(schedule.getStartTime() != null && schedule.getStopTime() == null) {
schedule.setStopTime(LocalDateTime.now()); schedule.setStopTime(LocalDateTime.now());
scheduleRepository.save(schedule); scheduleRepository.save(schedule);
Duration scheduleDuration = Duration.between(schedule.getStartTime(), schedule.getStopTime());
schedule.getTask().increaseWorkTime(scheduleDuration.toMinutes());
taskRepository.save(schedule.getTask());
} }
if(finish) { if(finish) {

View File

@ -14,7 +14,14 @@
</mat-card-header> </mat-card-header>
<mat-card-content> <mat-card-content>
<p>ETA: {{task!.eta}} Minuten - Deadline: {{task!.deadline}}</p> <p>ETA: {{task!.eta}} Minuten - Deadline: {{task!.deadline}}</p>
<mat-progress-bar [mode]="'determinate'" [value]="task!.workTime"></mat-progress-bar> <div class="progress-stacked" >
<div class="progress" role="progressbar" aria-label="Segment one" aria-valuenow="15" aria-valuemin="0" aria-valuemax="100" [style.width]=currentProgress>
<div class="progress-bar">{{currentProgress}}</div>
</div>
<div class="progress" role="progressbar" aria-label="Segment two" aria-valuenow="30" aria-valuemin="0" aria-valuemax="100" [style.width]=futureProgress>
<div class="progress-bar bg-success">{{futureProgress}}</div>
</div>
</div>
</mat-card-content> </mat-card-content>
<mat-card-actions *ngIf="taskgroup != undefined && task != undefined"> <mat-card-actions *ngIf="taskgroup != undefined && task != undefined">
<div style="width: 100%"> <div style="width: 100%">

View File

@ -2,6 +2,7 @@ import {Component, OnInit, ViewChild} from '@angular/core';
import {NavigationLink, NavigationLinkListComponent} from "../../navigation-link-list/navigation-link-list.component"; import {NavigationLink, NavigationLinkListComponent} from "../../navigation-link-list/navigation-link-list.component";
import {ActivatedRoute, Router} from "@angular/router"; import {ActivatedRoute, Router} from "@angular/router";
import { import {
AdvancedScheduleInfo,
ScheduleInfo, ScheduleInfo,
ScheduleService, ScheduleService,
TaskEntityInfo, TaskEntityInfo,
@ -41,8 +42,11 @@ export class TaskDetailOverviewComponent implements OnInit {
task: TaskEntityInfo | undefined task: TaskEntityInfo | undefined
schedules: ScheduleInfo[] = [] schedules: ScheduleInfo[] = []
schedulesLoaded: boolean = false;
taskStatus: string = "🟢" taskStatus: string = "🟢"
currentProgress: string = "0";
futureProgress: string = "0";
constructor(private activatedRoute: ActivatedRoute, constructor(private activatedRoute: ActivatedRoute,
private taskgroupService: TaskgroupService, private taskgroupService: TaskgroupService,
@ -83,11 +87,14 @@ export class TaskDetailOverviewComponent implements OnInit {
next: resp => { next: resp => {
this.task = resp; this.task = resp;
this.taskStatus = this.getStatusOfTask(resp) this.taskStatus = this.getStatusOfTask(resp)
this.calcProgress();
} }
}); });
this.scheduleService.schedulesTaskIDGet(Number(params.get('taskID'))).subscribe({ this.scheduleService.schedulesTaskIDGet(Number(params.get('taskID'))).subscribe({
next: resp => { next: resp => {
this.schedules = resp; this.schedules = resp;
this.schedulesLoaded = true;
this.calcProgress();
} }
}) })
} }
@ -97,13 +104,35 @@ export class TaskDetailOverviewComponent implements OnInit {
getStatusOfTask(task: TaskEntityInfo ) { getStatusOfTask(task: TaskEntityInfo ) {
if(moment(task.deadline, 'YYYY-MM-DDTHH:mm:ss.SSSZ').isBefore(moment())) { if(moment(task.deadline, 'YYYY-MM-DDTHH:mm:ss.SSSZ').isBefore(moment())) {
return "🔴"; return "🔴";
} else if(this.schedules.length == 0){ } else if(this.schedules.length == 0 && this.schedulesLoaded){
return "🟠"; return "🟠";
} else { } else {
return "🟢"; return "🟢";
} }
} }
calcProgress() {
if(this.task != undefined && this.task!.eta > 0) {
const currentProgress = this.task!.workTime / this.task!.eta * 100;
let futureProgress = 0;
this.schedules.forEach(schedule => {
if(schedule.scheduleType == "ADVANCED" && schedule.startTime == null) {
let advancedSchedule: AdvancedScheduleInfo = schedule as AdvancedScheduleInfo;
if(moment(advancedSchedule.scheduleStartTime).isBefore(moment())) {
const duration = moment.duration(moment(advancedSchedule.scheduleStopTime).diff(moment(advancedSchedule.scheduleStartTime)));
const plannedMinutes = duration.asMinutes();
futureProgress += plannedMinutes;
}
}
})
this.futureProgress = (futureProgress) / this.task!.eta *100 + "%";
this.currentProgress = currentProgress + "%";
}
}
openTaskEditor() { openTaskEditor() {
if(this.task != undefined) { if(this.task != undefined) {
const taskEditorInfo: TaskEditorData = { const taskEditorInfo: TaskEditorData = {