mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[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:
committed by
Eugenio Romano
parent
dd4c0e37f2
commit
d47a5bfbbf
@@ -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>
|
||||||
|
@@ -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');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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() {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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) => {
|
||||||
|
Reference in New Issue
Block a user