diff --git a/backend/src/main/java/ch/puzzle/okr/dto/ObjectiveDto.java b/backend/src/main/java/ch/puzzle/okr/dto/ObjectiveDto.java index bf230fdcc8..6afdfedadf 100644 --- a/backend/src/main/java/ch/puzzle/okr/dto/ObjectiveDto.java +++ b/backend/src/main/java/ch/puzzle/okr/dto/ObjectiveDto.java @@ -5,5 +5,6 @@ import java.time.LocalDateTime; public record ObjectiveDto(Long id, int version, String title, Long teamId, Long quarterId, String quarterLabel, - String description, State state, LocalDateTime createdOn, LocalDateTime modifiedOn, boolean writeable) { + String description, State state, LocalDateTime createdOn, LocalDateTime modifiedOn, boolean writeable, + boolean archived) { } diff --git a/backend/src/main/java/ch/puzzle/okr/mapper/ObjectiveMapper.java b/backend/src/main/java/ch/puzzle/okr/mapper/ObjectiveMapper.java index a65574c408..a0541add67 100644 --- a/backend/src/main/java/ch/puzzle/okr/mapper/ObjectiveMapper.java +++ b/backend/src/main/java/ch/puzzle/okr/mapper/ObjectiveMapper.java @@ -23,7 +23,7 @@ public ObjectiveDto toDto(Objective objective) { return new ObjectiveDto(objective.getId(), objective.getVersion(), objective.getTitle(), objective.getTeam().getId(), objective.getQuarter().getId(), objective.getQuarter().getLabel(), objective.getDescription(), objective.getState(), objective.getCreatedOn(), objective.getModifiedOn(), - objective.isWriteable()); + objective.isWriteable(), objective.isArchived()); } public Objective toObjective(ObjectiveDto objectiveDto) { @@ -31,6 +31,7 @@ public Objective toObjective(ObjectiveDto objectiveDto) { .withTitle(objectiveDto.title()).withTeam(teamBusinessService.getTeamById(objectiveDto.teamId())) .withDescription(objectiveDto.description()).withModifiedOn(LocalDateTime.now()) .withState(objectiveDto.state()).withCreatedOn(objectiveDto.createdOn()) - .withQuarter(quarterBusinessService.getQuarterById(objectiveDto.quarterId())).build(); + .withQuarter(quarterBusinessService.getQuarterById(objectiveDto.quarterId())) + .withArchived(objectiveDto.archived()).build(); } } diff --git a/backend/src/main/java/ch/puzzle/okr/models/Objective.java b/backend/src/main/java/ch/puzzle/okr/models/Objective.java index 85a96b59dd..acbbc438cf 100644 --- a/backend/src/main/java/ch/puzzle/okr/models/Objective.java +++ b/backend/src/main/java/ch/puzzle/okr/models/Objective.java @@ -51,6 +51,8 @@ public class Objective implements WriteableInterface { @ManyToOne private User modifiedBy; + private boolean archived; + private transient boolean writeable; public Objective() { @@ -68,6 +70,7 @@ private Objective(Builder builder) { setState(builder.state); setCreatedOn(builder.createdOn); setModifiedBy(builder.modifiedBy); + setArchived(builder.archived); } public Long getId() { @@ -150,6 +153,14 @@ public void setModifiedBy(User modifiedBy) { this.modifiedBy = modifiedBy; } + public boolean isArchived() { + return archived; + } + + public void setArchived(boolean archived) { + this.archived = archived; + } + @Override public boolean isWriteable() { return writeable; @@ -162,10 +173,10 @@ public void setWriteable(boolean writeable) { @Override public String toString() { - return "Objective{" + "id=" + id + ", version=" + version + ", title='" + title + '\'' + ", createdBy=" - + createdBy + ", team=" + team + ", quarter=" + quarter + ", description='" + description + '\'' - + ", modifiedOn=" + modifiedOn + ", state=" + state + ", createdOn=" + createdOn + ", modifiedBy=" - + modifiedBy + ", writeable=" + writeable + '\'' + '}'; + return "Objective{" + "id=" + id + ", version=" + version + ", title='" + title + '\'' + ", state=" + state + + ", description='" + description + '\'' + ", team=" + team + ", quarter=" + quarter + ", createdBy=" + + createdBy + ", createdOn=" + createdOn + ", modifiedOn=" + modifiedOn + ", modifiedBy=" + modifiedBy + + ", archived=" + archived + ", writeable=" + writeable + '}'; } @Override @@ -180,13 +191,14 @@ public boolean equals(Object o) { && Objects.equals(team, objective.team) && Objects.equals(quarter, objective.quarter) && Objects.equals(description, objective.description) && Objects.equals(modifiedOn, objective.modifiedOn) && state == objective.state - && Objects.equals(createdOn, objective.createdOn) && Objects.equals(modifiedBy, objective.modifiedBy); + && Objects.equals(createdOn, objective.createdOn) && Objects.equals(modifiedBy, objective.modifiedBy) + && Objects.equals(archived, objective.archived); } @Override public int hashCode() { - return Objects.hash(id, version, title, createdBy, team, quarter, description, modifiedOn, state, createdOn, - modifiedBy); + return Objects.hash(id, version, title, state, description, team, quarter, createdBy, createdOn, modifiedOn, + modifiedBy, archived); } public static final class Builder { @@ -201,6 +213,7 @@ public static final class Builder { private State state; private LocalDateTime createdOn; private User modifiedBy; + private boolean archived; private Builder() { } @@ -264,6 +277,11 @@ public Builder withModifiedBy(User modifiedBy) { return this; } + public Builder withArchived(boolean archived) { + this.archived = archived; + return this; + } + public Objective build() { return new Objective(this); } diff --git a/backend/src/main/java/ch/puzzle/okr/models/overview/Overview.java b/backend/src/main/java/ch/puzzle/okr/models/overview/Overview.java index b2b3eb6d79..2e21752b04 100644 --- a/backend/src/main/java/ch/puzzle/okr/models/overview/Overview.java +++ b/backend/src/main/java/ch/puzzle/okr/models/overview/Overview.java @@ -22,6 +22,7 @@ public class Overview implements WriteableInterface { @Enumerated(EnumType.STRING) private State objectiveState; private LocalDateTime objectiveCreatedOn; + private boolean objectiveArchived; private Long quarterId; private String quarterLabel; private String keyResultTitle; @@ -49,6 +50,7 @@ private Overview(Builder builder) { objectiveTitle = builder.objectiveTitle; objectiveState = builder.objectiveState; objectiveCreatedOn = builder.objectiveCreatedOn; + objectiveArchived = builder.objectiveArchived; quarterId = builder.quarterId; quarterLabel = builder.quarterLabel; keyResultTitle = builder.keyResultTitle; @@ -89,6 +91,10 @@ public LocalDateTime getObjectiveCreatedOn() { return objectiveCreatedOn; } + public boolean isObjectiveArchived() { + return objectiveArchived; + } + public Long getQuarterId() { return quarterId; } @@ -157,15 +163,15 @@ public void setWriteable(boolean writeable) { @Override public String toString() { - return "Overview{" + "overviewId=" + overviewId + ", teamVersion='" + teamVersion + ", teamName='" + teamName - + '\'' + ", objectiveTitle='" + objectiveTitle + '\'' + ", objectiveState=" + objectiveState - + ", objectiveCreatedOn=" + objectiveCreatedOn + ", quarterId=" + quarterId + ", quarterLabel='" - + quarterLabel + '\'' + ", keyResultTitle='" + keyResultTitle + '\'' + ", keyResultType='" - + keyResultType + '\'' + ", baseline=" + baseline + ", stretchGoal=" + stretchGoal + ", unit='" + unit - + '\'' + ", commitZone='" + commitZone + '\'' + ", targetZone='" + targetZone + '\'' + ", stretchZone='" - + stretchZone + '\'' + ", checkInValue=" + checkInValue + ", checkInZone='" + checkInZone + '\'' - + ", confidence=" + confidence + ", createdOn=" + checkInCreatedOn + ", writeable=" + writeable + '\'' - + '}'; + return "Overview{" + "overviewId=" + overviewId + ", teamName='" + teamName + '\'' + ", teamVersion=" + + teamVersion + ", objectiveTitle='" + objectiveTitle + '\'' + ", objectiveState=" + objectiveState + + ", objectiveCreatedOn=" + objectiveCreatedOn + ", objectiveArchived=" + objectiveArchived + + ", quarterId=" + quarterId + ", quarterLabel='" + quarterLabel + '\'' + ", keyResultTitle='" + + keyResultTitle + '\'' + ", keyResultType='" + keyResultType + '\'' + ", baseline=" + baseline + + ", stretchGoal=" + stretchGoal + ", unit='" + unit + '\'' + ", commitZone='" + commitZone + '\'' + + ", targetZone='" + targetZone + '\'' + ", stretchZone='" + stretchZone + '\'' + ", checkInValue=" + + checkInValue + ", checkInZone='" + checkInZone + '\'' + ", confidence=" + confidence + + ", checkInCreatedOn=" + checkInCreatedOn + ", writeable=" + writeable + '}'; } public static final class Builder { @@ -175,6 +181,7 @@ public static final class Builder { private String objectiveTitle; private State objectiveState; private LocalDateTime objectiveCreatedOn; + private boolean objectiveArchived; private Long quarterId; private String quarterLabel; private String keyResultTitle; @@ -227,6 +234,11 @@ public Builder withObjectiveCreatedOn(LocalDateTime objectiveCreatedOn) { return this; } + public Builder withObjectiveArchived(boolean objectiveArchived) { + this.objectiveArchived = objectiveArchived; + return this; + } + public Builder withQuarterId(Long quarterId) { this.quarterId = quarterId; return this; diff --git a/backend/src/main/java/ch/puzzle/okr/service/authorization/KeyResultAuthorizationService.java b/backend/src/main/java/ch/puzzle/okr/service/authorization/KeyResultAuthorizationService.java index edcced39f2..3f40da4a00 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/authorization/KeyResultAuthorizationService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/authorization/KeyResultAuthorizationService.java @@ -21,6 +21,17 @@ public KeyResultAuthorizationService(KeyResultBusinessService keyResultBusinessS super(keyResultBusinessService, authorizationService); } + @Override + public KeyResult getEntityById(Long id) { + AuthorizationUser authorizationUser = getAuthorizationService().getAuthorizationUser(); + hasRoleReadById(id, authorizationUser); + KeyResult keyResult = getBusinessService().getEntityById(id); + if (!keyResult.getObjective().isArchived()) { + keyResult.setWriteable(isWriteable(keyResult, authorizationUser)); + } + return keyResult; + } + @Override protected void hasRoleReadById(Long id, AuthorizationUser authorizationUser) { getAuthorizationService().hasRoleReadByKeyResultId(id, authorizationUser); @@ -45,7 +56,9 @@ public List getAllCheckInsByKeyResult(Long keyResultId) { AuthorizationUser authorizationUser = getAuthorizationService().getAuthorizationUser(); getAuthorizationService().hasRoleReadByKeyResultId(keyResultId, authorizationUser); List checkIns = getBusinessService().getAllCheckInsByKeyResult(keyResultId); - setRoleCreateOrUpdateCheckIn(checkIns, authorizationUser); + if (!checkIns.get(0).getKeyResult().getObjective().isArchived()) { + setRoleCreateOrUpdateCheckIn(checkIns, authorizationUser); + } return checkIns; } diff --git a/backend/src/main/java/ch/puzzle/okr/service/authorization/ObjectiveAuthorizationService.java b/backend/src/main/java/ch/puzzle/okr/service/authorization/ObjectiveAuthorizationService.java index bb213bf2d8..d3f4ab762e 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/authorization/ObjectiveAuthorizationService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/authorization/ObjectiveAuthorizationService.java @@ -19,6 +19,17 @@ public Objective duplicateEntity(Long id, Objective objective) { return getBusinessService().duplicateObjective(id, objective, authorizationUser); } + @Override + public Objective getEntityById(Long id) { + AuthorizationUser authorizationUser = getAuthorizationService().getAuthorizationUser(); + hasRoleReadById(id, authorizationUser); + Objective objective = getBusinessService().getEntityById(id); + if (!objective.isArchived()) { + objective.setWriteable(isWriteable(objective, authorizationUser)); + } + return objective; + } + @Override protected void hasRoleReadById(Long id, AuthorizationUser authorizationUser) { getAuthorizationService().hasRoleReadByObjectiveId(id, authorizationUser); diff --git a/backend/src/main/java/ch/puzzle/okr/service/authorization/OverviewAuthorizationService.java b/backend/src/main/java/ch/puzzle/okr/service/authorization/OverviewAuthorizationService.java index 5ee61cb4bf..76b82744eb 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/authorization/OverviewAuthorizationService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/authorization/OverviewAuthorizationService.java @@ -9,6 +9,7 @@ import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.Objects; import static ch.puzzle.okr.service.authorization.AuthorizationService.hasRoleWriteAll; @@ -28,7 +29,9 @@ public List getFilteredOverview(Long quarterId, List teamIds, St AuthorizationUser authorizationUser = authorizationService.getAuthorizationUser(); List overviews = overviewBusinessService.getFilteredOverview(quarterId, teamIds, objectiveQuery, authorizationUser); - setRoleCreateOrUpdateTeam(overviews, authorizationUser); + if (Objects.isNull(quarterId) || quarterId != 998) { + setRoleCreateOrUpdateTeam(overviews, authorizationUser); + } return overviews; } diff --git a/backend/src/main/java/ch/puzzle/okr/service/business/ObjectiveBusinessService.java b/backend/src/main/java/ch/puzzle/okr/service/business/ObjectiveBusinessService.java index b532aba932..ee9d8c53da 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/business/ObjectiveBusinessService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/business/ObjectiveBusinessService.java @@ -38,6 +38,10 @@ public ObjectiveBusinessService(@Lazy KeyResultBusinessService keyResultBusiness this.completedBusinessService = completedBusinessService; } + public List getAllObjectives() { + return objectivePersistenceService.findAll(); + } + public Objective getEntityById(Long id) { validator.validateOnGet(id); return objectivePersistenceService.findById(id); @@ -55,6 +59,7 @@ public Objective updateEntity(Long id, Objective objective, AuthorizationUser au objective.setCreatedOn(savedObjective.getCreatedOn()); objective.setModifiedBy(authorizationUser.user()); objective.setModifiedOn(LocalDateTime.now()); + objective.setArchived(false); String not = " "; if (isImUsed(objective, savedObjective)) { objective.setQuarter(savedObjective.getQuarter()); @@ -87,6 +92,7 @@ private static boolean hasQuarterChanged(Objective objective, Objective savedObj public Objective createEntity(Objective objective, AuthorizationUser authorizationUser) { objective.setCreatedBy(authorizationUser.user()); objective.setCreatedOn(LocalDateTime.now()); + objective.setArchived(false); validator.validateOnCreate(objective); return objectivePersistenceService.save(objective); } @@ -121,4 +127,10 @@ public void deleteEntityById(Long id) { .forEach(keyResult -> keyResultBusinessService.deleteEntityById(keyResult.getId())); objectivePersistenceService.deleteById(id); } + + public void archiveEntity(Long id) { + Objective savedObjective = objectivePersistenceService.findById(id); + savedObjective.setArchived(true); + objectivePersistenceService.save(savedObjective); + } } diff --git a/backend/src/main/java/ch/puzzle/okr/service/business/OverviewBusinessService.java b/backend/src/main/java/ch/puzzle/okr/service/business/OverviewBusinessService.java index 9955505137..4baa5b2dc9 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/business/OverviewBusinessService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/business/OverviewBusinessService.java @@ -35,8 +35,14 @@ public List getFilteredOverview(Long quarterId, List teamIds, St return List.of(); } - List overviews = overviewPersistenceService.getFilteredOverview(quarterId, teamIds, objectiveQuery, - authorizationUser); + List overviews; + if (quarterId == 998) { + overviews = overviewPersistenceService.getArchiveOverview(teamIds, objectiveQuery, authorizationUser); + overviews.forEach(overview -> overview.setWriteable(false)); + } else { + overviews = overviewPersistenceService.getFilteredOverview(quarterId, teamIds, objectiveQuery, + authorizationUser); + } return sortOverview(overviews, authorizationUser); } diff --git a/backend/src/main/java/ch/puzzle/okr/service/business/QuarterBusinessService.java b/backend/src/main/java/ch/puzzle/okr/service/business/QuarterBusinessService.java index 9d39d47eb5..957406c157 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/business/QuarterBusinessService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/business/QuarterBusinessService.java @@ -1,13 +1,11 @@ package ch.puzzle.okr.service.business; -import ch.puzzle.okr.ErrorKey; -import ch.puzzle.okr.exception.OkrResponseStatusException; +import ch.puzzle.okr.models.Objective; import ch.puzzle.okr.models.Quarter; import ch.puzzle.okr.service.persistence.QuarterPersistenceService; import ch.puzzle.okr.service.validation.QuarterValidationService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import org.springframework.http.HttpStatus; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Service; @@ -20,11 +18,13 @@ public class QuarterBusinessService { private static final Logger logger = LoggerFactory.getLogger(QuarterBusinessService.class); private final QuarterPersistenceService quarterPersistenceService; + private final ObjectiveBusinessService objectiveBusinessService; private final QuarterValidationService validator; public QuarterBusinessService(QuarterPersistenceService quarterPersistenceService, - QuarterValidationService validator) { + ObjectiveBusinessService objectiveBusinessService, QuarterValidationService validator) { this.quarterPersistenceService = quarterPersistenceService; + this.objectiveBusinessService = objectiveBusinessService; this.validator = validator; } @@ -36,7 +36,9 @@ public Quarter getQuarterById(Long quarterId) { public List getQuarters() { List mostCurrentQuarterList = quarterPersistenceService.getMostCurrentQuarters(); Quarter backlog = quarterPersistenceService.findByLabel("Backlog"); + Quarter archive = quarterPersistenceService.findByLabel("Archiv"); mostCurrentQuarterList.add(0, backlog); + mostCurrentQuarterList.add(archive); return mostCurrentQuarterList; } @@ -66,12 +68,27 @@ private void generateQuarter(YearMonth yearMonth) { .build(); validator.validateOnGeneration(quarter); quarterPersistenceService.save(quarter); + handleQuarterArchive(); } public YearMonth getCurrentYearMonth() { return YearMonth.now(); } + private void handleQuarterArchive() { + List mostCurrentQuarterList = quarterPersistenceService.getMostCurrentQuarters(); + Quarter backlog = quarterPersistenceService.findByLabel("Backlog"); + mostCurrentQuarterList.add(backlog); + List allObjectives = objectiveBusinessService.getAllObjectives(); + + allObjectives.forEach(objective -> { + if (!mostCurrentQuarterList.contains(objective.getQuarter())) { + objectiveBusinessService.archiveEntity(objective.getId()); + } + }); + logger.info("Update archived Objectives"); + } + @Scheduled(cron = "0 59 23 L * ?") // Cron expression for 23:59:00 on the last day of every month public void scheduledGenerationQuarters() { YearMonth yearMonth = getCurrentYearMonth(); diff --git a/backend/src/main/java/ch/puzzle/okr/service/persistence/OverviewPersistenceService.java b/backend/src/main/java/ch/puzzle/okr/service/persistence/OverviewPersistenceService.java index 197cdc5d9d..5f4cae8798 100644 --- a/backend/src/main/java/ch/puzzle/okr/service/persistence/OverviewPersistenceService.java +++ b/backend/src/main/java/ch/puzzle/okr/service/persistence/OverviewPersistenceService.java @@ -15,6 +15,7 @@ public class OverviewPersistenceService { private static final Logger logger = LoggerFactory.getLogger(OverviewPersistenceService.class); private static final String SELECT_OVERVIEW = "SELECT o FROM Overview o WHERE o.quarterId=:quarterId"; + private static final String SELECT_ARCHIVE = "SELECT o FROM Overview o WHERE o.objectiveArchived=true"; private final EntityManager entityManager; private final AuthorizationCriteria authorizationCriteria; @@ -35,4 +36,14 @@ public List getFilteredOverview(Long quarterId, List teamIds, St authorizationCriteria.setParameters(typedQuery, teamIds, objectiveQuery, authorizationUser); return typedQuery.getResultList(); } + + public List getArchiveOverview(List teamIds, String objectiveQuery, + AuthorizationUser authorizationUser) { + String queryString = SELECT_ARCHIVE + + authorizationCriteria.appendOverview(teamIds, objectiveQuery, authorizationUser); + logger.debug("select overview by teamIds={}: {}", teamIds, queryString); + TypedQuery typedQuery = entityManager.createQuery(queryString, Overview.class); + authorizationCriteria.setParameters(typedQuery, teamIds, objectiveQuery, authorizationUser); + return typedQuery.getResultList(); + } } diff --git a/backend/src/main/resources/db/migration/V2_1_3__addArchive.sql b/backend/src/main/resources/db/migration/V2_1_3__addArchive.sql new file mode 100644 index 0000000000..8cf9a84763 --- /dev/null +++ b/backend/src/main/resources/db/migration/V2_1_3__addArchive.sql @@ -0,0 +1,59 @@ +alter table objective + add column if not exists archived boolean; + +INSERT INTO quarter (id, label, start_date, end_date) +VALUES (998, 'Archiv', null, null); + +DO $$ + DECLARE + r record; + BEGIN + FOR r IN SELECT * FROM objective + WHERE objective.archived IS NULL + LOOP + UPDATE objective o + SET archived = false + WHERE o.id = r.id; + END LOOP; +END$$; + +alter table objective + alter column archived set not null; + +DROP VIEW IF EXISTS OVERVIEW; +CREATE VIEW OVERVIEW AS +SELECT tq.team_id AS "team_id", + tq.team_version AS "team_version", + tq.name AS "team_name", + tq.quater_id AS "quarter_id", + tq.label AS "quarter_label", + coalesce(o.id, -1) AS "objective_id", + o.title AS "objective_title", + o.state AS "objective_state", + o.created_on AS "objective_created_on", + CASE + WHEN o.title IS NOT NULL THEN o.archived + ELSE FALSE + END AS "objective_archived", + coalesce(kr.id, -1) AS "key_result_id", + kr.title AS "key_result_title", + kr.key_result_type AS "key_result_type", + kr.unit, + kr.baseline, + kr.stretch_goal, + kr.commit_zone, + kr.target_zone, + kr.stretch_zone, + coalesce(c.id, -1) AS "check_in_id", + c.value_metric AS "check_in_value", + c.zone AS "check_in_zone", + c.confidence, + c.created_on AS "check_in_created_on" +FROM (select t.id as team_id, t.version as team_version, t.name, q.id as quater_id, q.label + from team t, + quarter q) tq + LEFT JOIN OBJECTIVE O ON TQ.TEAM_ID = O.TEAM_ID AND TQ.QUATER_ID = O.QUARTER_ID + LEFT JOIN KEY_RESULT KR ON O.ID = KR.OBJECTIVE_ID + LEFT JOIN CHECK_IN C ON KR.ID = C.KEY_RESULT_ID AND C.MODIFIED_ON = (SELECT MAX(CC.MODIFIED_ON) + FROM CHECK_IN CC + WHERE CC.KEY_RESULT_ID = C.KEY_RESULT_ID); \ No newline at end of file diff --git a/backend/src/test/java/ch/puzzle/okr/controller/ObjectiveControllerIT.java b/backend/src/test/java/ch/puzzle/okr/controller/ObjectiveControllerIT.java index f4fbc5d68a..caa68c3a99 100644 --- a/backend/src/test/java/ch/puzzle/okr/controller/ObjectiveControllerIT.java +++ b/backend/src/test/java/ch/puzzle/okr/controller/ObjectiveControllerIT.java @@ -79,9 +79,9 @@ class ObjectiveControllerIT { .withCreatedBy(user).withTeam(team).withQuarter(quarter).withDescription(DESCRIPTION) .withModifiedOn(LocalDateTime.MAX).build(); private static final ObjectiveDto objective1Dto = new ObjectiveDto(5L, 1, OBJECTIVE_TITLE_1, 1L, 1L, "GJ 22/23-Q2", - DESCRIPTION, State.DRAFT, LocalDateTime.MAX, LocalDateTime.MAX, true); + DESCRIPTION, State.DRAFT, LocalDateTime.MAX, LocalDateTime.MAX, true, false); private static final ObjectiveDto objective2Dto = new ObjectiveDto(7L, 1, OBJECTIVE_TITLE_2, 1L, 1L, "GJ 22/23-Q2", - DESCRIPTION, State.DRAFT, LocalDateTime.MIN, LocalDateTime.MIN, true); + DESCRIPTION, State.DRAFT, LocalDateTime.MIN, LocalDateTime.MIN, true, false); @Autowired private MockMvc mvc; @@ -119,7 +119,7 @@ void getObjectiveByIdFail() throws Exception { @Test void shouldReturnObjectiveWhenCreatingNewObjective() throws Exception { ObjectiveDto testObjective = new ObjectiveDto(null, 1, "Program Faster", 1L, 1L, "GJ 22/23-Q2", - "Just be faster", State.DRAFT, null, null, true); + "Just be faster", State.DRAFT, null, null, true, false); BDDMockito.given(objectiveMapper.toDto(any())).willReturn(testObjective); BDDMockito.given(objectiveAuthorizationService.createEntity(any())).willReturn(fullObjective); @@ -144,7 +144,7 @@ void shouldReturnResponseStatusExceptionWhenCreatingObjectiveWithNullValues() th @Test void shouldReturnUpdatedObjective() throws Exception { ObjectiveDto testObjective = new ObjectiveDto(1L, 1, TITLE, 1L, 1L, "GJ 22/23-Q2", EVERYTHING_FINE_DESCRIPTION, - State.NOTSUCCESSFUL, LocalDateTime.MIN, LocalDateTime.MAX, true); + State.NOTSUCCESSFUL, LocalDateTime.MIN, LocalDateTime.MAX, true, false); Objective objective = Objective.Builder.builder().withId(1L).withDescription(EVERYTHING_FINE_DESCRIPTION) .withTitle(TITLE).build(); @@ -162,7 +162,7 @@ void shouldReturnUpdatedObjective() throws Exception { @Test void shouldReturnImUsed() throws Exception { ObjectiveDto testObjectiveDto = new ObjectiveDto(1L, 1, TITLE, 1L, 1L, "GJ 22/23-Q2", - EVERYTHING_FINE_DESCRIPTION, State.SUCCESSFUL, LocalDateTime.MAX, LocalDateTime.MAX, true); + EVERYTHING_FINE_DESCRIPTION, State.SUCCESSFUL, LocalDateTime.MAX, LocalDateTime.MAX, true, false); Objective objectiveImUsed = Objective.Builder.builder().withId(1L).withDescription(EVERYTHING_FINE_DESCRIPTION) .withQuarter(Quarter.Builder.builder().withId(1L).withLabel("GJ 22/23-Q2").build()).withTitle(TITLE) .build(); diff --git a/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.ts b/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.ts index 2b967cabd8..a5d6ccdeb9 100644 --- a/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.ts +++ b/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.ts @@ -87,7 +87,7 @@ export class ObjectiveFormComponent implements OnInit { : of(this.getDefaultObjective()); forkJoin([objective$, this.quarters$]).subscribe(([objective, quarters]) => { - this.quarters = quarters; + this.quarters = quarters.filter((quarter) => quarter.label !== 'Archiv'); const teamId = isCreating ? objective.teamId : this.data.objective.teamId; let quarterId = getValueFromQuery(this.route.snapshot.queryParams['quarter'], quarters[1].id)[0]; @@ -98,6 +98,7 @@ export class ObjectiveFormComponent implements OnInit { this.state = objective.state; this.version = objective.version; + this.quarters$ = of(this.quarters); this.teams$.subscribe((value) => { this.currentTeam.next(value.filter((team) => team.id == teamId)[0]); });