diff --git a/.run/OkrApplication-local-prod-debug.run.xml b/.run/OkrApplication-local-prod-debug.run.xml
new file mode 100755
index 0000000000..15ae63f4ef
--- /dev/null
+++ b/.run/OkrApplication-local-prod-debug.run.xml
@@ -0,0 +1,17 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/backend/pom.xml b/backend/pom.xml
index fd75300b5e..55b2f44dd9 100644
--- a/backend/pom.xml
+++ b/backend/pom.xml
@@ -83,6 +83,15 @@
3.26.3
test
+
+ org.springframework.boot
+ spring-boot-devtools
+
+
+ org.springframework
+ springloaded
+ 1.2.8.RELEASE
+
diff --git a/frontend/package.json b/frontend/package.json
index 4c12464841..08e2415442 100644
--- a/frontend/package.json
+++ b/frontend/package.json
@@ -3,7 +3,7 @@
"version": "2.0.0",
"scripts": {
"ng": "ng",
- "start": "ng serve ",
+ "start": "ng serve",
"build": "ng build",
"build:staging": "ng build --configuration staging",
"watch": "ng build --watch --configuration development",
diff --git a/frontend/src/app/components/check-in-history-dialog/check-in-history-dialog.component.ts b/frontend/src/app/components/check-in-history-dialog/check-in-history-dialog.component.ts
index 4241ad6426..7b8a93d8fe 100644
--- a/frontend/src/app/components/check-in-history-dialog/check-in-history-dialog.component.ts
+++ b/frontend/src/app/components/check-in-history-dialog/check-in-history-dialog.component.ts
@@ -48,6 +48,7 @@ export class CheckInHistoryDialogComponent implements OnInit {
});
dialogRef.afterClosed().subscribe(() => {
this.loadCheckInHistory();
+ this.refreshDataService.reloadKeyResultSubject.next();
this.refreshDataService.markDataRefresh();
});
}
diff --git a/frontend/src/app/components/keyresult-detail/keyresult-detail.component.spec.ts b/frontend/src/app/components/keyresult-detail/keyresult-detail.component.spec.ts
index c0e0055357..ebaec251bc 100644
--- a/frontend/src/app/components/keyresult-detail/keyresult-detail.component.spec.ts
+++ b/frontend/src/app/components/keyresult-detail/keyresult-detail.component.spec.ts
@@ -12,6 +12,7 @@ import { MatIconModule } from '@angular/material/icon';
import { ActivatedRoute } from '@angular/router';
import { ScoringComponent } from '../../shared/custom/scoring/scoring.component';
import { ConfidenceComponent } from '../confidence/confidence.component';
+import { RefreshDataService } from '../../services/refresh-data.service';
const keyResultServiceMock = {
getFullKeyResult: jest.fn(),
@@ -87,4 +88,21 @@ describe('KeyresultDetailComponent', () => {
const button = fixture.debugElement.query(By.css('[data-testId="add-check-in"]'));
expect(button).toBeFalsy();
});
+
+ it('should trigger observable when subject gets next value', () => {
+ const spy = jest.spyOn(component, 'loadKeyResult');
+ const refreshDataService = TestBed.inject(RefreshDataService);
+ refreshDataService.reloadKeyResultSubject.next();
+ expect(spy).toHaveBeenCalled();
+ });
+
+ it('should close subscription on destroy', () => {
+ const spyNext = jest.spyOn(component.ngDestroy$, 'next');
+ const spyComplete = jest.spyOn(component.ngDestroy$, 'complete');
+
+ component.ngOnDestroy();
+
+ expect(spyNext).toHaveBeenCalled();
+ expect(spyComplete).toHaveBeenCalled();
+ });
});
diff --git a/frontend/src/app/components/keyresult-detail/keyresult-detail.component.ts b/frontend/src/app/components/keyresult-detail/keyresult-detail.component.ts
index d31fae0dfb..62e728dcf2 100644
--- a/frontend/src/app/components/keyresult-detail/keyresult-detail.component.ts
+++ b/frontend/src/app/components/keyresult-detail/keyresult-detail.component.ts
@@ -1,11 +1,11 @@
-import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';
+import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit } from '@angular/core';
import { KeyResult } from '../../shared/types/model/KeyResult';
import { KeyresultService } from '../../services/keyresult.service';
import { KeyResultMetric } from '../../shared/types/model/KeyResultMetric';
import { KeyResultOrdinal } from '../../shared/types/model/KeyResultOrdinal';
import { CheckInHistoryDialogComponent } from '../check-in-history-dialog/check-in-history-dialog.component';
import { MatDialog } from '@angular/material/dialog';
-import { BehaviorSubject, catchError, EMPTY } from 'rxjs';
+import { BehaviorSubject, catchError, EMPTY, Subject, takeUntil } from 'rxjs';
import { ActivatedRoute, Router } from '@angular/router';
import { RefreshDataService } from '../../services/refresh-data.service';
import { CloseState } from '../../shared/types/enums/CloseState';
@@ -22,10 +22,11 @@ import { ConfirmDialogComponent } from '../../shared/dialog/confirm-dialog/confi
styleUrls: ['./keyresult-detail.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
})
-export class KeyresultDetailComponent implements OnInit {
+export class KeyresultDetailComponent implements OnInit, OnDestroy {
@Input() keyResultId!: number;
keyResult$: BehaviorSubject = new BehaviorSubject({} as KeyResult);
+ ngDestroy$: Subject = new Subject();
isComplete: boolean = false;
protected readonly DATE_FORMAT = DATE_FORMAT;
protected readonly isLastCheckInNegative = isLastCheckInNegative;
@@ -41,6 +42,14 @@ export class KeyresultDetailComponent implements OnInit {
ngOnInit(): void {
this.keyResultId = this.getIdFromParams();
this.loadKeyResult(this.keyResultId);
+ this.refreshDataService.reloadKeyResultSubject.pipe(takeUntil(this.ngDestroy$)).subscribe(() => {
+ this.loadKeyResult(this.keyResultId);
+ });
+ }
+
+ ngOnDestroy() {
+ this.ngDestroy$.next();
+ this.ngDestroy$.complete();
}
private getIdFromParams(): number {
@@ -181,7 +190,7 @@ export class KeyresultDetailComponent implements OnInit {
},
});
dialogRef.afterClosed().subscribe(() => {
- this.loadKeyResult(this.keyResult$.getValue().id);
+ this.refreshDataService.reloadKeyResultSubject.next();
this.refreshDataService.markDataRefresh();
});
}
diff --git a/frontend/src/app/services/refresh-data.service.ts b/frontend/src/app/services/refresh-data.service.ts
index fe5a7f5f7a..3c1a1fb321 100644
--- a/frontend/src/app/services/refresh-data.service.ts
+++ b/frontend/src/app/services/refresh-data.service.ts
@@ -7,6 +7,7 @@ import { DEFAULT_HEADER_HEIGHT_PX } from '../shared/constantLibary';
})
export class RefreshDataService {
public reloadOverviewSubject: Subject = new Subject();
+ public reloadKeyResultSubject: Subject = new Subject();
public quarterFilterReady: Subject = new Subject();
public teamFilterReady: Subject = new Subject();