[ADF-3432 ]Added size and page control to task list demo (#3674)

* [ADF-3432] Added size and page control to task listdemo

* [ADF-3432] Removed console log

* [ADF-3432] Errors catched on TaskList component when a bad query is made

* [ADF-3432] It reloads task list content when form is reset

* [ADF-3432] Fixed missing whitespace lint error

* remove unused dependency
This commit is contained in:
davidcanonieto
2018-08-14 09:27:59 +02:00
committed by Eugenio Romano
parent dd4c0e37f2
commit d47a5bfbbf
4 changed files with 71 additions and 34 deletions

View File

@@ -7,9 +7,6 @@
matInput matInput
class="form-control" class="form-control"
[formControl]="taskAppId"> [formControl]="taskAppId">
<mat-error *ngIf="taskAppId.hasError('required')">
{{ 'TASK_LIST_DEMO.ERROR_MESSAGE.APP_ID_REQUIRED_ERROR' | translate }}
</mat-error>
<mat-error *ngIf="taskAppId.hasError('pattern')"> <mat-error *ngIf="taskAppId.hasError('pattern')">
{{ 'TASK_LIST_DEMO.ERROR_MESSAGE.APP_ID_TYPE_ERROR' | translate }} {{ 'TASK_LIST_DEMO.ERROR_MESSAGE.APP_ID_TYPE_ERROR' | translate }}
</mat-error> </mat-error>
@@ -61,6 +58,22 @@
<mat-hint>E.g. 12345</mat-hint> <mat-hint>E.g. 12345</mat-hint>
</mat-form-field> </mat-form-field>
<mat-form-field>
<mat-label>Items per page</mat-label>
<input
matInput
class="form-control"
[formControl]="taskSize">
</mat-form-field>
<mat-form-field>
<mat-label>Page</mat-label>
<input
matInput
class="form-control"
[formControl]="taskPage">
</mat-form-field>
<mat-form-field> <mat-form-field>
<mat-label>Process Instance</mat-label> <mat-label>Process Instance</mat-label>
<mat-select <mat-select
@@ -113,8 +126,9 @@
[state]="state" [state]="state"
[sort]="sort" [sort]="sort"
[start]="start" [start]="start"
[page]="page"
[size]="size"
[includeProcessInstance]="includeProcessInstance" [includeProcessInstance]="includeProcessInstance"
(error)="onError($event)"
#taskList> #taskList>
<data-columns> <data-columns>
<data-column key="id" title="Id"></data-column> <data-column key="id" title="Id"></data-column>

View File

@@ -18,7 +18,6 @@
import { Component, OnInit } from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { FormGroup, FormBuilder, Validators, FormControl, AbstractControl } from '@angular/forms'; import { FormGroup, FormBuilder, Validators, FormControl, AbstractControl } from '@angular/forms';
import { ActivatedRoute, Params } from '@angular/router'; import { ActivatedRoute, Params } from '@angular/router';
import { NotificationService } from '@alfresco/adf-core';
import { debounceTime } from 'rxjs/operators'; import { debounceTime } from 'rxjs/operators';
@Component({ @Component({
@@ -52,6 +51,10 @@ export class TaskListDemoComponent implements OnInit {
start: number; start: number;
size: number;
page: number;
includeProcessInstance: boolean; includeProcessInstance: boolean;
assignmentOptions = [ assignmentOptions = [
@@ -78,8 +81,7 @@ export class TaskListDemoComponent implements OnInit {
]; ];
constructor(private route: ActivatedRoute, constructor(private route: ActivatedRoute,
private formBuilder: FormBuilder, private formBuilder: FormBuilder) {
private notificationService: NotificationService) {
} }
ngOnInit() { ngOnInit() {
@@ -87,8 +89,6 @@ export class TaskListDemoComponent implements OnInit {
this.route.params.forEach((params: Params) => { this.route.params.forEach((params: Params) => {
if (params['id']) { if (params['id']) {
this.defaultAppId = +params['id']; this.defaultAppId = +params['id'];
} else {
this.defaultAppId = 0;
} }
}); });
} }
@@ -101,7 +101,7 @@ export class TaskListDemoComponent implements OnInit {
buildForm() { buildForm() {
this.taskListForm = this.formBuilder.group({ this.taskListForm = this.formBuilder.group({
taskAppId: new FormControl(this.defaultAppId, [Validators.required, Validators.pattern('^[0-9]*$')]), taskAppId: new FormControl(this.defaultAppId, [Validators.pattern('^[0-9]*$')]),
taskName: new FormControl(''), taskName: new FormControl(''),
taskId: new FormControl(''), taskId: new FormControl(''),
taskProcessDefinitionId: new FormControl(''), taskProcessDefinitionId: new FormControl(''),
@@ -109,6 +109,8 @@ export class TaskListDemoComponent implements OnInit {
taskAssignment: new FormControl(''), taskAssignment: new FormControl(''),
taskState: new FormControl(''), taskState: new FormControl(''),
taskSort: new FormControl(''), taskSort: new FormControl(''),
taskSize: new FormControl(''),
taskPage: new FormControl(''),
taskStart: new FormControl('', [Validators.pattern('^[0-9]*$')]), taskStart: new FormControl('', [Validators.pattern('^[0-9]*$')]),
taskIncludeProcessInstance: new FormControl('') taskIncludeProcessInstance: new FormControl('')
}); });
@@ -134,19 +136,29 @@ export class TaskListDemoComponent implements OnInit {
this.state = taskFilter.taskState; this.state = taskFilter.taskState;
this.sort = taskFilter.taskSort; this.sort = taskFilter.taskSort;
this.start = taskFilter.taskStart; this.start = taskFilter.taskStart;
this.size = taskFilter.taskSize;
this.page = taskFilter.taskPage;
this.includeProcessInstance = taskFilter.taskIncludeProcessInstance === 'include'; this.includeProcessInstance = taskFilter.taskIncludeProcessInstance === 'include';
} }
onError($event) {
const errorMessage = JSON.parse($event.message).message;
this.notificationService.openSnackMessageAction(errorMessage, 'Reset', 5000).onAction().subscribe(() => {
this.resetTaskForm();
});
}
resetTaskForm() { resetTaskForm() {
this.taskListForm.reset(); this.taskListForm.reset();
this.resetQueryParameters();
}
resetQueryParameters() {
this.appId = null;
this.id = null;
this.processDefinitionId = null;
this.processInstanceId = null;
this.name = null;
this.assignment = null;
this.state = null;
this.sort = null;
this.start = null;
this.size = null;
this.page = null;
} }
isFormValid() { isFormValid() {
@@ -192,4 +204,12 @@ export class TaskListDemoComponent implements OnInit {
get taskStart(): AbstractControl { get taskStart(): AbstractControl {
return this.taskListForm.get('taskStart'); return this.taskListForm.get('taskStart');
} }
get taskSize(): AbstractControl {
return this.taskListForm.get('taskSize');
}
get taskPage(): AbstractControl {
return this.taskListForm.get('taskPage');
}
} }

View File

@@ -17,11 +17,13 @@
import { TaskDetailsModel } from './task-details.model'; import { TaskDetailsModel } from './task-details.model';
export interface TaskListModel { export class TaskListModel {
size: number; size: number;
total: number; total: number;
start: number; start: number;
length: number; length: number;
data: TaskDetailsModel []; data: TaskDetailsModel[] = [];
constructor() {
}
} }

View File

@@ -17,7 +17,7 @@
import { AlfrescoApiService, LogService } from '@alfresco/adf-core'; import { AlfrescoApiService, LogService } from '@alfresco/adf-core';
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { Observable, from, forkJoin, throwError } from 'rxjs'; import { Observable, from, forkJoin, throwError, of } from 'rxjs';
import { map, catchError, switchMap, flatMap, filter } from 'rxjs/operators'; import { map, catchError, switchMap, flatMap, filter } from 'rxjs/operators';
import { FilterRepresentationModel, TaskQueryRequestRepresentationModel } from '../models/filter.model'; import { FilterRepresentationModel, TaskQueryRequestRepresentationModel } from '../models/filter.model';
import { Form } from '../models/form.model'; import { Form } from '../models/form.model';
@@ -66,7 +66,7 @@ export class TaskListService {
* @param filter The filter you want to check * @param filter The filter you want to check
* @returns The filter if it is related or null otherwise * @returns The filter if it is related or null otherwise
*/ */
isTaskRelatedToFilter(taskId: string, filterModel: FilterRepresentationModel): Observable<FilterRepresentationModel> { isTaskRelatedToFilter(taskId: string, filterModel: FilterRepresentationModel): Observable<FilterRepresentationModel> {
let requestNodeForFilter = this.generateTaskRequestNodeFromFilter(filterModel); let requestNodeForFilter = this.generateTaskRequestNodeFromFilter(filterModel);
return from(this.callApiTasksFiltered(requestNodeForFilter)) return from(this.callApiTasksFiltered(requestNodeForFilter))
.pipe( .pipe(
@@ -99,7 +99,8 @@ export class TaskListService {
if (state) { if (state) {
requestNode.state = state; requestNode.state = state;
} }
return this.getTasks(requestNode); return this.getTasks(requestNode)
.pipe(catchError(() => of(new TaskListModel())));
} }
/** /**
@@ -128,15 +129,15 @@ export class TaskListService {
*/ */
findAllTasksWithoutState(requestNode: TaskQueryRequestRepresentationModel): Observable<TaskListModel> { findAllTasksWithoutState(requestNode: TaskQueryRequestRepresentationModel): Observable<TaskListModel> {
return forkJoin( return forkJoin(
this.findTasksByState(requestNode, 'open'), this.findTasksByState(requestNode, 'open'),
this.findAllTaskByState(requestNode, 'completed'), this.findAllTaskByState(requestNode, 'completed'),
(activeTasks: TaskListModel, completedTasks: TaskListModel) => { (activeTasks: TaskListModel, completedTasks: TaskListModel) => {
const tasks = Object.assign({}, activeTasks); const tasks = Object.assign({}, activeTasks);
tasks.total += completedTasks.total; tasks.total += completedTasks.total;
tasks.data = tasks.data.concat(completedTasks.data); tasks.data = tasks.data.concat(completedTasks.data);
return tasks; return tasks;
} }
); );
} }
/** /**
@@ -177,7 +178,7 @@ export class TaskListService {
* Gets all available reusable forms. * Gets all available reusable forms.
* @returns Array of form details * @returns Array of form details
*/ */
getFormList(): Observable<Form []> { getFormList(): Observable<Form[]> {
let opts = { let opts = {
'filter': 'myReusableForms', // String | filter 'filter': 'myReusableForms', // String | filter
'sort': 'modifiedDesc', // String | sort 'sort': 'modifiedDesc', // String | sort
@@ -204,7 +205,7 @@ export class TaskListService {
* @returns Null response notifying when the operation is complete * @returns Null response notifying when the operation is complete
*/ */
attachFormToATask(taskId: string, formId: number): Observable<any> { attachFormToATask(taskId: string, formId: number): Observable<any> {
return from(this.apiService.taskApi.attachForm(taskId, {'formId': formId})) return from(this.apiService.taskApi.attachForm(taskId, { 'formId': formId }))
.pipe( .pipe(
catchError(err => this.handleError(err)) catchError(err => this.handleError(err))
); );
@@ -299,7 +300,7 @@ export class TaskListService {
* @returns Details of the assigned task * @returns Details of the assigned task
*/ */
assignTask(taskId: string, requestNode: any): Observable<TaskDetailsModel> { assignTask(taskId: string, requestNode: any): Observable<TaskDetailsModel> {
let assignee = {assignee: requestNode.id}; let assignee = { assignee: requestNode.id };
return from(this.callApiAssignTask(taskId, assignee)) return from(this.callApiAssignTask(taskId, assignee))
.pipe( .pipe(
map((response: TaskDetailsModel) => { map((response: TaskDetailsModel) => {