Skip to content

Commit

Permalink
Use second refresh subject
Browse files Browse the repository at this point in the history
  • Loading branch information
lkleisa committed Jun 24, 2024
1 parent 89de0e4 commit 6b9a56b
Show file tree
Hide file tree
Showing 9 changed files with 37 additions and 74 deletions.
16 changes: 0 additions & 16 deletions frontend/cypress/e2e/checkIn.cy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,6 @@ describe('OKR Check-in e2e tests', () => {
checkForDialogTextMetric();
cy.fillOutCheckInMetric(30, 6, 'We bought a new house', 'We have to buy more PCs');

cy.wait(1000);

cy.contains('30%');
cy.contains('6/10');
cy.contains('Letztes Check-in (' + getCurrentDate() + ')');
Expand Down Expand Up @@ -64,8 +62,6 @@ describe('OKR Check-in e2e tests', () => {
checkForDialogTextMetric();
cy.fillOutCheckInMetric(30, 0, 'We bought a new house', 'We have to buy more PCs');

cy.wait(100);

cy.contains('30%');
cy.contains('6/10');
cy.contains('Letztes Check-in (' + getCurrentDate() + ')');
Expand Down Expand Up @@ -96,8 +92,6 @@ describe('OKR Check-in e2e tests', () => {
checkForDialogTextMetric();
cy.fillOutCheckInMetric(5, 5, null, null);

cy.wait(500);

cy.contains('5%');
cy.contains('!');
cy.contains('5/10');
Expand Down Expand Up @@ -130,8 +124,6 @@ describe('OKR Check-in e2e tests', () => {
checkForDialogTextOrdinal();
cy.fillOutCheckInOrdinal(1, 6, 'There is a new car', 'Buy now a new pool');

cy.wait(500);

cy.contains('6/10');
cy.contains('There is a new car');
cy.contains('Letztes Check-in (' + getCurrentDate() + ')');
Expand Down Expand Up @@ -162,8 +154,6 @@ describe('OKR Check-in e2e tests', () => {
cy.getByTestId('add-check-in').first().click();
cy.fillOutCheckInMetric(50, 6, 'This was a good idea', 'Will be difficult');

cy.wait(500);

cy.getByTestId('show-all-checkins').click();

cy.wait(500);
Expand Down Expand Up @@ -201,9 +191,6 @@ describe('OKR Check-in e2e tests', () => {

cy.getByTestId('add-check-in').first().click();
cy.fillOutCheckInMetric(30, 5, 'Here we are', 'A cat would be great');

cy.wait(500);

cy.contains('Aktuell: CHF 30.-');
cy.getByTestId('show-all-checkins').click();

Expand Down Expand Up @@ -249,9 +236,6 @@ describe('OKR Check-in e2e tests', () => {
cy.getByTestId('keyresult').contains('For editing ordinal checkin').click();
cy.getByTestId('add-check-in').first().click();
cy.fillOutCheckInOrdinal(0, 6, 'There is a new car', 'Buy now a new pool');

cy.wait(500);

cy.getByTestId('show-all-checkins').click();

cy.wait(500);
Expand Down
1 change: 0 additions & 1 deletion frontend/cypress/e2e/scoring.cy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,6 @@ describe('Scoring component e2e tests', () => {

function setupMetricKR(baseline: number, stretchgoal: number, value: number) {
cy.createMetricKeyresult('Metric scoring keyresult', String(baseline), String(stretchgoal));
cy.wait(500);
cy.getByTestId('keyresult').get(':contains("Metric scoring keyresult")').last().click();
cy.getByTestId('add-check-in').click();
cy.getByTestId('check-in-metric-value').clear().type(String(value));
Expand Down
4 changes: 2 additions & 2 deletions frontend/src/app/diagram/diagram.component.html
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<div *ngIf="(alignmentDataCache?.alignmentObjectDtoList)!.length != 0" id="cy"></div>
<div *ngIf="((alignmentData$ | async)?.alignmentObjectDtoList)!.length != 0" id="cy"></div>

<div
*ngIf="(alignmentDataCache?.alignmentObjectDtoList)!.length == 0"
*ngIf="((alignmentData$ | async)?.alignmentObjectDtoList)!.length == 0"
class="d-flex align-items-center flex-column pt-5 gap-5"
>
<p>Kein Alignment vorhanden</p>
Expand Down
5 changes: 1 addition & 4 deletions frontend/src/app/diagram/diagram.component.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ describe('DiagramComponent', () => {
jest.spyOn(component, 'prepareDiagramData');

component.ngAfterViewInit();
component.alignmentData.next(alignmentLists);
component.alignmentData$.next(alignmentLists);

expect(component.cleanUpDiagram).toHaveBeenCalled();
expect(component.prepareDiagramData).toHaveBeenCalledWith(alignmentLists);
Expand Down Expand Up @@ -104,7 +104,6 @@ describe('DiagramComponent', () => {
component.generateNodes(alignmentLists);

expect(component.generateConnections).toHaveBeenCalled();
expect(component.generateDiagram).toHaveBeenCalled();
expect(component.diagramData).toEqual(diagramElements.concat(edges));
});

Expand All @@ -120,7 +119,6 @@ describe('DiagramComponent', () => {
component.generateNodes(alignmentListsKeyResult);

expect(component.generateConnections).toHaveBeenCalled();
expect(component.generateDiagram).toHaveBeenCalled();
expect(component.diagramData).toEqual(diagramData);
});

Expand All @@ -136,7 +134,6 @@ describe('DiagramComponent', () => {
component.generateNodes(alignmentListsKeyResult);

expect(component.generateConnections).toHaveBeenCalled();
expect(component.generateDiagram).toHaveBeenCalled();
expect(component.diagramData).toEqual(diagramData);
});

Expand Down
47 changes: 20 additions & 27 deletions frontend/src/app/diagram/diagram.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,46 +21,35 @@ import { AlignmentObject } from '../shared/types/model/AlignmentObject';
import { AlignmentConnection } from '../shared/types/model/AlignmentConnection';
import { Zone } from '../shared/types/enums/Zone';
import { ObjectiveState } from '../shared/types/enums/ObjectiveState';
import { RefreshDataService } from '../shared/services/refresh-data.service';

@Component({
selector: 'app-diagram',
templateUrl: './diagram.component.html',
styleUrl: './diagram.component.scss',
})
export class DiagramComponent implements AfterViewInit, OnDestroy {
private alignmentData$: Subject<AlignmentLists> = new Subject<AlignmentLists>();
@Input()
public alignmentData$: Subject<AlignmentLists> = new Subject<AlignmentLists>();
cy!: cytoscape.Core;
diagramData: any[] = [];
alignmentDataCache: AlignmentLists | null = null;
reloadRequired: boolean | null | undefined = false;

constructor(
private keyResultService: KeyresultService,
private refreshDataService: RefreshDataService,
private router: Router,
) {}

@Input()
get alignmentData(): Subject<AlignmentLists> {
return this.alignmentData$;
}

set alignmentData(alignmentData: AlignmentLists) {
this.alignmentData$.next(alignmentData);
}

ngAfterViewInit(): void {
this.alignmentData.subscribe((alignmentData: AlignmentLists): void => {
let lastAlignmentItem: AlignmentObject =
alignmentData.alignmentObjectDtoList[alignmentData.alignmentObjectDtoList.length - 1];

const diagramReloadRequired: boolean =
lastAlignmentItem?.objectTitle === 'reload'
? lastAlignmentItem?.objectType === 'true'
: JSON.stringify(this.alignmentDataCache) !== JSON.stringify(alignmentData);
this.refreshDataService.reloadAlignmentSubject.subscribe((value: boolean | null | undefined): void => {
this.reloadRequired = value;
});

if (diagramReloadRequired) {
if (lastAlignmentItem?.objectTitle === 'reload') {
alignmentData.alignmentObjectDtoList.pop();
}
this.alignmentData$.subscribe((alignmentData: AlignmentLists): void => {
if (this.reloadRequired == true || JSON.stringify(this.alignmentDataCache) !== JSON.stringify(alignmentData)) {
this.reloadRequired = undefined;
this.alignmentDataCache = alignmentData;
this.diagramData = [];
this.cleanUpDiagram();
Expand All @@ -71,7 +60,8 @@ export class DiagramComponent implements AfterViewInit, OnDestroy {

ngOnDestroy(): void {
this.cleanUpDiagram();
this.alignmentData.unsubscribe();
this.alignmentData$.unsubscribe();
this.refreshDataService.reloadAlignmentSubject.unsubscribe();
}

generateDiagram(): void {
Expand Down Expand Up @@ -187,8 +177,8 @@ export class DiagramComponent implements AfterViewInit, OnDestroy {
}
});

zip(observableArray).subscribe(() => {
this.generateConnections(alignmentData, diagramElements);
zip(observableArray).subscribe(async () => {
await this.generateConnections(alignmentData, diagramElements);
});
}

Expand Down Expand Up @@ -223,7 +213,7 @@ export class DiagramComponent implements AfterViewInit, OnDestroy {
};
}

generateConnections(alignmentData: AlignmentLists, diagramElements: any[]): void {
async generateConnections(alignmentData: AlignmentLists, diagramElements: any[]) {
let edges: any[] = [];
alignmentData.alignmentConnectionDtoList.forEach((alignmentConnection: AlignmentConnection) => {
let edge = {
Expand All @@ -238,7 +228,10 @@ export class DiagramComponent implements AfterViewInit, OnDestroy {
edges.push(edge);
});
this.diagramData = diagramElements.concat(edges);
this.generateDiagram();

// Sometimes the DOM Element #cy is not ready when cytoscape tries to generate the diagram
// To avoid this, we use here a setTimeout()
setTimeout(() => this.generateDiagram(), 0);
}

generateObjectiveSVG(title: string, teamName: string, state: string): string {
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/app/overview/overview.component.html
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@
</div>

<div [class.hidden]="isOverview">
<app-diagram [alignmentData]="(alignmentLists$ | async) || emptyAlignmentList"></app-diagram>
<app-diagram [alignmentData$]="alignmentLists$"></app-diagram>
</div>
</div>
</div>
6 changes: 3 additions & 3 deletions frontend/src/app/overview/overview.component.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ describe('OverviewComponent', () => {
routerHarness.detectChanges();
component.loadOverviewWithParams();
expect(overviewService.getOverview).toHaveBeenCalledWith(quarterParam, teamsParam, objectiveQueryParam);
expect(component.loadOverview).toHaveBeenCalledWith(quarterParam, teamsParam, objectiveQueryParam, undefined);
expect(component.loadOverview).toHaveBeenCalledWith(quarterParam, teamsParam, objectiveQueryParam);
},
);

Expand All @@ -145,7 +145,7 @@ describe('OverviewComponent', () => {
jest.spyOn(overviewService, 'getOverview');
component.isOverview = true;

component.loadOverview(3, [5, 6], '', null);
component.loadOverview(3, [5, 6], '');
expect(overviewService.getOverview).toHaveBeenCalled();
});

Expand All @@ -154,7 +154,7 @@ describe('OverviewComponent', () => {
component.isOverview = false;
fixture.detectChanges();

component.loadOverview(3, [5, 6], '', null);
component.loadOverview(3, [5, 6], '');
expect(alignmentService.getAlignmentByFilter).toHaveBeenCalled();
});

Expand Down
24 changes: 6 additions & 18 deletions frontend/src/app/overview/overview.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import { RefreshDataService } from '../shared/services/refresh-data.service';
import { getQueryString, getValueFromQuery, isMobileDevice, trackByFn } from '../shared/common';
import { AlignmentService } from '../shared/services/alignment.service';
import { AlignmentLists } from '../shared/types/model/AlignmentLists';
import { AlignmentObject } from '../shared/types/model/AlignmentObject';

@Component({
selector: 'app-overview',
Expand All @@ -18,7 +17,6 @@ import { AlignmentObject } from '../shared/types/model/AlignmentObject';
export class OverviewComponent implements OnInit, OnDestroy {
overviewEntities$: Subject<OverviewEntity[]> = new Subject<OverviewEntity[]>();
alignmentLists$: Subject<AlignmentLists> = new Subject<AlignmentLists>();
emptyAlignmentList: AlignmentLists = { alignmentObjectDtoList: [], alignmentConnectionDtoList: [] } as AlignmentLists;
protected readonly trackByFn = trackByFn;
private destroyed$: ReplaySubject<boolean> = new ReplaySubject(1);
hasAdminAccess: ReplaySubject<boolean> = new ReplaySubject<boolean>(1);
Expand All @@ -34,7 +32,7 @@ export class OverviewComponent implements OnInit, OnDestroy {
) {
this.refreshDataService.reloadOverviewSubject
.pipe(takeUntil(this.destroyed$))
.subscribe((reload: boolean | null | undefined) => this.loadOverviewWithParams(reload));
.subscribe(() => this.loadOverviewWithParams());

combineLatest([
refreshDataService.teamFilterReady.asObservable(),
Expand All @@ -58,22 +56,22 @@ export class OverviewComponent implements OnInit, OnDestroy {
}
}

loadOverviewWithParams(reload?: boolean | null) {
loadOverviewWithParams() {
const quarterQuery = this.activatedRoute.snapshot.queryParams['quarter'];
const teamQuery = this.activatedRoute.snapshot.queryParams['teams'];
const objectiveQuery = this.activatedRoute.snapshot.queryParams['objectiveQuery'];

const teamIds = getValueFromQuery(teamQuery);
const quarterId = getValueFromQuery(quarterQuery)[0];
const objectiveQueryString = getQueryString(objectiveQuery);
this.loadOverview(quarterId, teamIds, objectiveQueryString, reload);
this.loadOverview(quarterId, teamIds, objectiveQueryString);
}

loadOverview(quarterId?: number, teamIds?: number[], objectiveQuery?: string, reload?: boolean | null): void {
loadOverview(quarterId?: number, teamIds?: number[], objectiveQuery?: string): void {
if (this.isOverview) {
this.loadOverviewData(quarterId, teamIds, objectiveQuery);
} else {
this.loadAlignmentData(quarterId, teamIds, objectiveQuery, reload);
this.loadAlignmentData(quarterId, teamIds, objectiveQuery);
}
}

Expand All @@ -92,7 +90,7 @@ export class OverviewComponent implements OnInit, OnDestroy {
});
}

loadAlignmentData(quarterId?: number, teamIds?: number[], objectiveQuery?: string, reload?: boolean | null): void {
loadAlignmentData(quarterId?: number, teamIds?: number[], objectiveQuery?: string): void {
this.alignmentService
.getAlignmentByFilter(quarterId, teamIds, objectiveQuery)
.pipe(
Expand All @@ -102,16 +100,6 @@ export class OverviewComponent implements OnInit, OnDestroy {
}),
)
.subscribe((alignmentLists: AlignmentLists) => {
if (reload != null) {
let alignmentObjectReload: AlignmentObject = {
objectId: 0,
objectTitle: 'reload',
objectType: reload.toString(),
objectTeamName: '',
objectState: null,
};
alignmentLists.alignmentObjectDtoList.push(alignmentObjectReload);
}
this.alignmentLists$.next(alignmentLists);
});
}
Expand Down
6 changes: 4 additions & 2 deletions frontend/src/app/shared/services/refresh-data.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,16 @@ import { DEFAULT_HEADER_HEIGHT_PX } from '../constantLibary';
providedIn: 'root',
})
export class RefreshDataService {
public reloadOverviewSubject: Subject<boolean | null | undefined> = new Subject();
public reloadOverviewSubject: Subject<void> = new Subject();
public reloadAlignmentSubject: Subject<boolean | null | undefined> = new Subject();

public quarterFilterReady: Subject<void> = new Subject<void>();
public teamFilterReady: Subject<void> = new Subject<void>();

public okrBannerHeightSubject: BehaviorSubject<number> = new BehaviorSubject<number>(DEFAULT_HEADER_HEIGHT_PX);

markDataRefresh(reload?: boolean | null) {
this.reloadOverviewSubject.next(reload);
this.reloadOverviewSubject.next();
this.reloadAlignmentSubject.next(reload);
}
}

0 comments on commit 6b9a56b

Please sign in to comment.