From bb7e816bdb7abebd835eb9b2f44ae343c3e31f7b Mon Sep 17 00:00:00 2001 From: Geoffrey Kwan Date: Sun, 4 Aug 2024 12:54:27 -0400 Subject: [PATCH 1/2] fix(Events): Duplicate node entered and node exited events (#1875) --- .../wise5/services/studentDataService.ts | 15 +++- src/assets/wise5/vle/node/node.component.ts | 59 ++++--------- src/assets/wise5/vle/vle.component.ts | 82 ++++++++++--------- 3 files changed, 69 insertions(+), 87 deletions(-) diff --git a/src/assets/wise5/services/studentDataService.ts b/src/assets/wise5/services/studentDataService.ts index 45c73c52230..db576cca5e2 100644 --- a/src/assets/wise5/services/studentDataService.ts +++ b/src/assets/wise5/services/studentDataService.ts @@ -26,17 +26,20 @@ export class StudentDataService extends DataService { private componentDirtySource: Subject = new Subject(); public componentDirty$: Observable = this.componentDirtySource.asObservable(); private componentSaveTriggeredSource: Subject = new Subject(); - public componentSaveTriggered$: Observable = this.componentSaveTriggeredSource.asObservable(); + public componentSaveTriggered$: Observable = + this.componentSaveTriggeredSource.asObservable(); private componentSubmitDirtySource: Subject = new Subject(); public componentSubmitDirty$: Observable = this.componentSubmitDirtySource.asObservable(); private componentSubmitTriggeredSource: Subject = new Subject(); - public componentSubmitTriggered$: Observable = this.componentSubmitTriggeredSource.asObservable(); + public componentSubmitTriggered$: Observable = + this.componentSubmitTriggeredSource.asObservable(); private componentStudentDataSource: Subject = new Subject(); public componentStudentData$: Observable = this.componentStudentDataSource.asObservable(); private dataRetrievedSource: Subject = new Subject(); public dataRetrieved$: Observable = this.dataRetrievedSource.asObservable(); private studentWorkSavedToServerSource: Subject = new Subject(); - public studentWorkSavedToServer$: Observable = this.studentWorkSavedToServerSource.asObservable(); + public studentWorkSavedToServer$: Observable = + this.studentWorkSavedToServerSource.asObservable(); private navItemIsExpandedSource: Subject = new Subject(); public navItemIsExpanded$: Observable = this.navItemIsExpandedSource.asObservable(); private nodeStatusesChangedSource: Subject = new Subject(); @@ -281,6 +284,12 @@ export class StudentDataService extends DataService { return this.saveToServer(componentStates, events, annotations); } + saveEvents(events: any): Promise { + const componentStates = undefined; + const annotations = undefined; + return this.saveToServer(componentStates, events, annotations); + } + createNewEvent(nodeId, componentId, context, componentType, category, event, data) { return { nodeId: nodeId, diff --git a/src/assets/wise5/vle/node/node.component.ts b/src/assets/wise5/vle/node/node.component.ts index 3f135a31267..f6e233cf7ac 100644 --- a/src/assets/wise5/vle/node/node.component.ts +++ b/src/assets/wise5/vle/node/node.component.ts @@ -133,16 +133,20 @@ export class NodeComponent implements OnInit { }) ); - this.studentDataService.currentNodeChanged$.subscribe(() => { - this.nodeUnloaded(this.node.id); - if (this.node.isEvaluateTransitionLogicOn('exitNode')) { - this.nodeService.evaluateTransitionLogic(); - } - this.initializeNode(); - }); - this.studentDataService.nodeStatusesChanged$.subscribe(() => { - this.updateComponentVisibility(); - }); + this.subscriptions.add( + this.studentDataService.currentNodeChanged$.subscribe(() => { + if (this.node.isEvaluateTransitionLogicOn('exitNode')) { + this.nodeService.evaluateTransitionLogic(); + } + this.initializeNode(); + }) + ); + + this.subscriptions.add( + this.studentDataService.nodeStatusesChanged$.subscribe(() => { + this.updateComponentVisibility(); + }) + ); } initializeNode(): void { @@ -165,22 +169,6 @@ export class NodeComponent implements OnInit { this.latestComponentState = latestComponentState; } - const componentId = null; - const componentType = null; - const category = 'Navigation'; - const event = 'nodeEntered'; - const eventData = { - nodeId: this.node.id - }; - this.studentDataService.saveVLEEvent( - this.node.id, - componentId, - componentType, - category, - event, - eventData - ); - if (this.configService.isPreview()) { this.rubric = this.node.rubric; this.showRubric = this.rubric != null && this.rubric != ''; @@ -444,29 +432,10 @@ export class NodeComponent implements OnInit { ); } - private nodeUnloaded(nodeId: string): void { - const componentId = null; - const componentType = null; - const category = 'Navigation'; - const event = 'nodeExited'; - const eventData = { - nodeId: nodeId - }; - this.studentDataService.saveVLEEvent( - nodeId, - componentId, - componentType, - category, - event, - eventData - ); - } - private registerExitListener(): void { this.subscriptions.add( this.sessionService.exit$.subscribe(() => { this.stopAutoSaveInterval(); - this.nodeUnloaded(this.node.id); }) ); } diff --git a/src/assets/wise5/vle/vle.component.ts b/src/assets/wise5/vle/vle.component.ts index 1efdef902a4..dd7a8ec21af 100644 --- a/src/assets/wise5/vle/vle.component.ts +++ b/src/assets/wise5/vle/vle.component.ts @@ -14,7 +14,7 @@ import { ActivatedRoute, Router } from '@angular/router'; import { WiseLinkService } from '../../../app/services/wiseLinkService'; import { convertToPNGFile } from '../common/canvas/canvas'; import { NodeStatusService } from '../services/nodeStatusService'; -import { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser'; +import { SafeResourceUrl } from '@angular/platform-browser'; @Component({ selector: 'vle', @@ -55,6 +55,11 @@ export class VLEComponent implements AfterViewInit { private wiseLinkService: WiseLinkService ) {} + @HostListener('window:beforeunload') + beforeUnload(): void { + this.saveNodeExitedEvent(); + } + ngAfterViewInit(): void { this.initializeVLEService.initialized$.subscribe((initialized: boolean) => { if (initialized) { @@ -103,6 +108,7 @@ export class VLEComponent implements AfterViewInit { this.currentNode = this.studentDataService.getCurrentNode(); this.setLayoutState(); this.initializeSubscriptions(); + this.saveNodeEnteredEvent(); } ngOnDestroy() { @@ -165,49 +171,17 @@ export class VLEComponent implements AfterViewInit { this.subscriptions.add( this.studentDataService.currentNodeChanged$.subscribe(({ previousNode }) => { this.currentNode = this.studentDataService.getCurrentNode(); - let currentNodeId = this.currentNode.id; - + const currentNodeId = this.currentNode.id; this.studentDataService.updateStackHistory(currentNodeId); this.nodeStatusService.setNodeIsVisited(currentNodeId); - - let componentId, componentType, category, eventName, eventData, eventNodeId; - if (previousNode != null && this.projectService.isGroupNode(previousNode.id)) { - // going from group to node or group to group - componentId = null; - componentType = null; - category = 'Navigation'; - eventName = 'nodeExited'; - eventData = { - nodeId: previousNode.id - }; - eventNodeId = previousNode.id; - this.studentDataService.saveVLEEvent( - eventNodeId, - componentId, - componentType, - category, - eventName, - eventData - ); + const events = []; + if (previousNode != null) { + events.push(this.createNodeExitedEvent(previousNode.id)); } + events.push(this.createNodeEnteredEvent()); + this.studentDataService.saveEvents(events); if (this.projectService.isGroupNode(currentNodeId)) { - componentId = null; - componentType = null; - category = 'Navigation'; - eventName = 'nodeEntered'; - eventData = { - nodeId: currentNodeId - }; - eventNodeId = currentNodeId; - this.studentDataService.saveVLEEvent( - eventNodeId, - componentId, - componentType, - category, - eventName, - eventData - ); } else { this.scrollToTop(); } @@ -387,4 +361,34 @@ export class VLEComponent implements AfterViewInit { } }; } + + private saveNodeEnteredEvent(): void { + this.studentDataService.saveEvents([this.createNodeEnteredEvent()]); + } + + private saveNodeExitedEvent(): void { + this.studentDataService.saveEvents([this.createNodeExitedEvent()]); + } + + private createNodeEnteredEvent(): any { + return this.createNodeEvent('nodeEntered'); + } + + private createNodeExitedEvent(nodeId: string = this.currentNode.id): any { + return this.createNodeEvent('nodeExited', nodeId); + } + + private createNodeEvent(eventName: string, nodeId: string = this.currentNode.id): any { + return this.studentDataService.createNewEvent( + nodeId, + null, + 'VLE', + null, + 'Navigation', + eventName, + { + nodeId: nodeId + } + ); + } } From 399f78c092fd56ede49831f47a6c76e35da3495d Mon Sep 17 00:00:00 2001 From: Geoffrey Kwan Date: Sun, 4 Aug 2024 13:50:14 -0400 Subject: [PATCH 2/2] refactor(WorkgroupNodeStatusComponent): Convert to standalone (#1876) --- .../workgroup-node-status.component.ts | 8 +++----- src/app/teacher/grading-common.module.ts | 4 ++-- .../milestone-workgroup-item.component.html | 3 +-- .../workgroup-item/workgroup-item.component.html | 3 +-- .../studentGrading/step-item/step-item.component.html | 3 +-- src/messages.xlf | 4 ++-- 6 files changed, 10 insertions(+), 15 deletions(-) diff --git a/src/app/classroom-monitor/workgroup-node-status/workgroup-node-status.component.ts b/src/app/classroom-monitor/workgroup-node-status/workgroup-node-status.component.ts index bc53c22ae7b..dc3d47ce4c1 100644 --- a/src/app/classroom-monitor/workgroup-node-status/workgroup-node-status.component.ts +++ b/src/app/classroom-monitor/workgroup-node-status/workgroup-node-status.component.ts @@ -2,12 +2,10 @@ import { Component, Input } from '@angular/core'; @Component({ selector: 'workgroup-node-status', + standalone: true, template: `{{ statusText }}` }) export class WorkgroupNodeStatusComponent { - @Input() - statusClass: string = 'text-secondary'; - - @Input() - statusText: string; + @Input() statusClass: string = 'text-secondary'; + @Input() statusText: string; } diff --git a/src/app/teacher/grading-common.module.ts b/src/app/teacher/grading-common.module.ts index 39b2c01db38..e9327561d28 100644 --- a/src/app/teacher/grading-common.module.ts +++ b/src/app/teacher/grading-common.module.ts @@ -20,7 +20,8 @@ import { NavItemProgressComponent } from '../classroom-monitor/nav-item-progress ComponentGradingModule, IntersectionObserverModule, StatusIconComponent, - StudentTeacherCommonModule + StudentTeacherCommonModule, + WorkgroupNodeStatusComponent ], declarations: [ EditComponentAnnotationsComponent, @@ -32,7 +33,6 @@ import { NavItemProgressComponent } from '../classroom-monitor/nav-item-progress WorkgroupInfoComponent, WorkgroupItemComponent, WorkgroupNodeScoreComponent, - WorkgroupNodeStatusComponent, WorkgroupSelectAutocompleteComponent ], exports: [ diff --git a/src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html b/src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html index 12010f382bc..c017d0a1952 100644 --- a/src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html +++ b/src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html @@ -25,8 +25,7 @@ >
- - +
- - +
diff --git a/src/assets/wise5/classroomMonitor/classroomMonitorComponents/studentGrading/step-item/step-item.component.html b/src/assets/wise5/classroomMonitor/classroomMonitorComponents/studentGrading/step-item/step-item.component.html index 43a1328f6f3..aaa8a272dc4 100644 --- a/src/assets/wise5/classroomMonitor/classroomMonitorComponents/studentGrading/step-item/step-item.component.html +++ b/src/assets/wise5/classroomMonitor/classroomMonitorComponents/studentGrading/step-item/step-item.component.html @@ -24,8 +24,7 @@ />
- - +
diff --git a/src/messages.xlf b/src/messages.xlf index 42601bc94f5..bb53217d93a 100644 --- a/src/messages.xlf +++ b/src/messages.xlf @@ -13675,14 +13675,14 @@ Click "Cancel" to keep the invalid JSON open so you can fix it.Step src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html - 73 + 72 Step src/assets/wise5/classroomMonitor/classroomMonitorComponents/milestones/milestone-workgroup-item/milestone-workgroup-item.component.html - 95 + 94