From f389adc325f3558b783bbd71d1e00f5dfb42e6f0 Mon Sep 17 00:00:00 2001 From: manasa Date: Fri, 22 Sep 2023 12:35:48 +0530 Subject: [PATCH] Only 1 open task displayed within case task lists issue fixed --- .../auto-complete/auto-complete.component.ts | 4 +- .../widget/todo/todo.component.html | 10 +- .../_components/widget/todo/todo.component.ts | 117 +++++++++--------- 3 files changed, 67 insertions(+), 64 deletions(-) diff --git a/packages/angular-sdk-components/src/app/_components/field/auto-complete/auto-complete.component.ts b/packages/angular-sdk-components/src/app/_components/field/auto-complete/auto-complete.component.ts index 008f226e..3d97e23a 100644 --- a/packages/angular-sdk-components/src/app/_components/field/auto-complete/auto-complete.component.ts +++ b/packages/angular-sdk-components/src/app/_components/field/auto-complete/auto-complete.component.ts @@ -158,10 +158,10 @@ export class AutoCompleteComponent implements OnInit { this.listType = 'datapage'; datasource = datasourceMetadata.datasource.name; this.parameters = this.flattenParameters(datasourceMetadata?.datasource?.parameters); - const displayProp = datasourceMetadata.datasource.propertyForDisplayText.startsWith('@P') + const displayProp = datasourceMetadata.datasource.propertyForDisplayText?.startsWith('@P') ? datasourceMetadata.datasource.propertyForDisplayText.substring(3) : datasourceMetadata.datasource.propertyForDisplayText; - const valueProp = datasourceMetadata.datasource.propertyForValue.startsWith('@P') + const valueProp = datasourceMetadata.datasource.propertyForValue?.startsWith('@P') ? datasourceMetadata.datasource.propertyForValue.substring(3) : datasourceMetadata.datasource.propertyForValue; columns = [ diff --git a/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.html b/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.html index 312c168c..505eb364 100644 --- a/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.html +++ b/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.html @@ -12,26 +12,26 @@
{{ this.currentUserInitials$ }}
-
{{ assignment.stepName }}
+
{{getAssignmentName(assignment)}}
-
+
Task in {{ assignment.name }} {{ getID(assignment) }} {{ assignment?.status }} - • Priority {{ assignment?.priority }} + • Urgency {{ getPriority(assignment) }}
- +
-
+
diff --git a/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.ts b/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.ts index f3e4de81..a9b13627 100644 --- a/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.ts +++ b/packages/angular-sdk-components/src/app/_components/widget/todo/todo.component.ts @@ -34,6 +34,8 @@ export class TodoComponent implements OnInit { bShowMore$: boolean = true; arAssignments$: Array; assignmentsSource$: any; + CONSTS: any; + bLogging = true; constructor(private psService: ProgressSpinnerService, private ngZone: NgZone, private utils: Utils) {} @@ -41,7 +43,7 @@ export class TodoComponent implements OnInit { if (!this.PCore$) { this.PCore$ = window.PCore; } - + this.CONSTS = this.PCore$.getConstants(); const { CREATE_STAGE_SAVED, CREATE_STAGE_DELETED } = this.PCore$.getEvents().getCaseEvent(); this.PCore$.getPubSubUtils().subscribe( @@ -136,59 +138,58 @@ export class TodoComponent implements OnInit { } getID(assignment: any) { - let sID = ''; if (assignment.value) { - let refKey = assignment.value; - sID = refKey.substring(refKey.lastIndexOf(' ') + 1); + const refKey = assignment.value; + return refKey.substring(refKey.lastIndexOf(' ') + 1); } else { - let refKey = assignment.ID; - let arKeys = refKey.split('!')[0].split(' '); - - sID = arKeys[2]; + const refKey = assignment.ID; + const arKeys = refKey.split('!')[0].split(' '); + return arKeys[2]; } + } - return sID; + topThreeAssignments(assignmentsSource: Array): Array { + return Array.isArray(assignmentsSource) ? assignmentsSource.slice(0, 3) : []; } - topThreeAssignments(arList: Array) { - let arList3: Array = new Array(); + getAssignmentId(assignment) { + return this.type$ === this.CONSTS.TODO ? assignment.ID : assignment.id; + }; - if (arList && typeof arList == 'object') { - let len = arList.length; - if (len > 3) len = 3; + getPriority(assignment) { + return this.type$ === this.CONSTS.TODO ? assignment.urgency : assignment.priority; + }; - for (let i = 0; i < len; i++) { - arList3.push(arList[i]); - } - } + getAssignmentName(assignment) { + return this.type$ === this.CONSTS.TODO ? assignment.name : assignment.stepName; + }; - return arList3; + initAssignments(): Array { + if (this.assignmentsSource$) { + this.assignmentCount$ = this.assignmentsSource$.length; + return this.topThreeAssignments(this.assignmentsSource$); + } else { + // turn off todolist + return []; + } } - getCaseInfoAssignment(arList: Array, caseInfoID: string) { - let arList1: Array = new Array(); - for (var aIndex in arList) { - if (arList[aIndex].ID.indexOf(caseInfoID) >= 0) { - let listRow = JSON.parse(JSON.stringify(arList[aIndex])); - + getCaseInfoAssignment(assignmentsSource: Array, caseInfoID: string) { + const result: Array = []; + for (const source of assignmentsSource) { + if (source.ID.indexOf(caseInfoID) >= 0) { + const listRow = JSON.parse(JSON.stringify(source)); // urgency becomes priority - if (listRow.urgency) { - listRow['priority'] = listRow.urgency; - } - - if (listRow.ID) { - // mimic regular list - listRow['id'] = listRow['ID']; - } - - arList1.push(listRow); - break; + listRow['priority'] = listRow.urgency || undefined; + // mimic regular list + listRow['id'] = listRow['ID'] || undefined; + result.push(listRow); } } - - return arList1; + + return result; } - + _showMore() { this.ngZone.run(() => { this.bShowMore$ = false; @@ -204,40 +205,42 @@ export class TodoComponent implements OnInit { }); } - clickGo(assignment: any) { - let { id, classname } = assignment[0]; - - // capture className, as seem to loose it when - if (classname == null || classname == '') { - classname = this.pConn$.getCaseInfo().getClassName(); - } + isChildCase(assignment) { + return assignment.isChild; + }; - let sTarget = this.pConn$.getContainerName(); - let sTargetContainerName = sTarget; - let sIsActionFromTodoList = 'todo'; + clickGo(assignment) { + const id = this.getAssignmentId(assignment); + let { classname = '' } = assignment; + const sTarget = this.pConn$.getContainerName(); + const sTargetContainerName = sTarget; - let options = { containerName: sTarget }; + const options = { containerName: sTargetContainerName }; - if (classname == null || classname == '') { + if (classname === null || classname === '') { classname = this.pConn$.getCaseInfo().getClassName(); } if (sTarget === 'workarea') { options['isActionFromToDoList'] = true; options['target'] = ''; - options['context'] = this.context$; - options['isChild'] = undefined; + options['context'] = null; + options['isChild'] = this.isChildCase(assignment); } else { options['isActionFromToDoList'] = false; options['target'] = sTarget; - options['context'] = ''; } - this.psService.sendMessage(true); - this.pConn$ .getActionsApi() .openAssignment(id, classname, options) - .then(() => {}); + .then(() => { + if (this.bLogging) { + console.log(`openAssignment completed`); + } + }) + .catch(() => { + alert(`Submit failed!`); + }); } }